首页 > 代码库 > 使用Django时需要注意的八个要点

使用Django时需要注意的八个要点

1.settings.py中使用os. path.dirname()

常用代码如下:

1 # settings.py2 import os3 PROJECT_DIR = os.path.dirname(__file__)4 STATIC_ROOT = os.path.join(PROJECT_DIR, "static")5 ...6 TEMPLATE_DIRS = (7     os.path.join(PROJECT_DIR, "templates"),8 )

__file__变量表示当前文件,PROJECT_DIR则取得了当前文件的绝对路径,这样做的好处是避免在settings.py中硬编码文件路径.

 

2.使用locals()为模板传递参数

Python 内建函数 locals() ,返回对所有局部变量的名称与值进行映射的字典.

在实际开发中,不需要为模板写出每一个变量,比如:

return render_to_response(‘template.html‘, {"var1": var1, "var2":var2}, context_instance=RequestContext(request))

优化后代码为:

return render_to_response(‘template.html‘, locals(), context_instance=RequestContext(request))

由此延伸:

render_dict = locals()render_dict[‘also_needs‘] = "this value"return render_to_response(‘template.html‘, render_dict, context_instance=RequestContext(request))

 

3.部署时将DEBUG设置成False

自动处理的执行代码:

import socketif socket.gethostname() == ‘XXX-MOBL‘:    DEBUG = Falseelse:    DEBUG = True

 

4.使用exists()函数判断是否取得数据

减少性能的代码:

books = Books.objects.filter(author__last_name=‘Brown‘)if books:    # Do something

或者

books = Books.objects.filter(author__last_name=‘Brown‘)if len(books):    # Do something

执行books = Books.Object…语句时并没有连接数据库,进行下一步判断才会实际对数据库进行操作.

exists()函数会判断只要存在数据,就会返回1,不会load模型属性或者在DB和APP之间传递大型数据.

所以,使用exists函数能提高性能,如下:

books = Books.objects.filter(author__last_name=‘Brown‘)if books.exists():    # Do something 

 

5.合理配置使用URLs

不要将所有url配置在 (mysite/urls.py)一个文件内,可以根据不同Apps,分别配置在自己的urls.py文件中,这样做的好处之一是简洁明了,并可以容易重复使用App到不同的项目中,示例代码如下:

urlpatterns = patterns(‘‘,    url(r‘^polls/‘, include(‘polls.urls‘, namespace="polls")),    url(r‘^admin/‘, include(admin.site.urls)),)

在polls的urls.py文件中存在如下代码:

from polls import viewsurlpatterns = patterns(‘‘,    url(r‘^$‘, views.index, name=‘index‘),    url(r‘^(?P<poll_id>\d+)/$‘, views.detail, name=‘detail‘),    url(r‘^(?P<poll_id>\d+)/results/$‘, views.results, name=‘results‘),)

比如想实现如下功能,其中硬编码了/polls/,以后有相应变动,会很麻烦.

<li><a href="http://www.mamicode.com/polls/{{ poll.id }}/">{{ poll.question }}</a></li>

优化后的代码如下:

<li><a href="http://www.mamicode.com/{% url ‘polls.detail‘ poll.id %}">{{ poll.question }}</a></li>

{% url %}标签会根据”polls.detail”在mysite/urls.py文件中寻找namespage=”polls”的相应URL,假如poll.id变量为5,演化后的实际代码想象中就是:

<li><a href="http://www.mamicode.com/项目根目录/polls/5/">{{ poll.question }}</a></li>

这样做另外的好处是,避免了在template中硬编码URL,这也是django编程中要注意的要点(不要在模板中硬编码URL

 

6.不要在模板中硬编码静态文件路径

不好的代码示范:

<img src="http://www.mamicode.com/static/images/test.png">{{ poll.question }}</img>

Django.contrib. staticfiles是静态资源管理的一个App, 相关的设置settings.py主要有三个:

STATIC_ROOT:  项目部署时,需要将所有用到的静态文件(包括INSTALLED_APPS下各个App的static文件夹下文件和STATICFILES_DIRS设置目录下文件)收集到一个目录,交给服务器进行处理(在项目实际部署时,要配置服务器来服务这个目录),STATIC_ROOT就是那个目录,只有在运行collectstatic命令时才会用到.

STATIC_URL:  静态文件的起始目录,浏览器访问时的地址前缀,如果STATIC_URL = /test/,runserver后,任意静态文件的路径都将以/test/开始,即”/test/”代表了STATIC_ROOT.(可以随意修改STATIC_URL值,但是必须以斜线开始,否者找不到静态文件地址).

STATICFILES_DIRS:  除了各个app的static目录以外,其他还需要管理的静态文件设置.

 

优化后的代码:

<img src="http://www.mamicode.com/{{ STATIC_URL }}/images/test.png">{{ poll.question }}</img>

或者

{% load staticfiles %}<img src="http://www.mamicode.com/{% static"my_app/myexample.jpg" %}" alt="My image"/>

PS{% static %}{{ STATIC_URL}}的使用不同之处,待解决

 

7.只加载一次自定义的模板标签

当需要使用自定义或者第三方的模板标签和模板过滤器时,通常要在模板中使用如下代码:

{% load cms_tags %} 

实际情况是,需要在所有用到自定义模板标签和模板过滤器的模板中都使用上面的代码.

为了DRY, 优化后的解决办法是:将以下代码加到项目启动时能加载的文件中(setting.py、urls.py文件 etc.)

from django import templatetemplate.add_to_builtins(cms.templatetags.cms_tags)

 

8. 了解一些第三方应用

a. 数据迁移 —— South

常用命令:

python manage.py schemamigration youappname –initialpython manage.py schemamigration youappname --auto #检测对models的更改python manage.py migrate youappnampython manage.py syncdb

b. Django Debug ——Django-debug-toolbar (使用ing…)

 

使用Django时需要注意的八个要点