使用Django时需要注意的八个要点
1.在settings.py中使用os. path.dirname()
常用代码如下:
# settings.py
import os
PROJECT_DIR = os.path.dirname(__file__)
STATIC_ROOT = os.path.join(PROJECT_DIR, "static")
...
TEMPLATE_DIRS = (
os.path.join(PROJECT_DIR, "templates"),
)
__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 socket
if socket.gethostname() == 'XXX-MOBL':
DEBUG = False
else:
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 views
urlpatterns = 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="/polls/{{ poll.id }}/">{{ poll.question }}</a></li>
优化后的代码如下:
<li><a href="{% url 'polls.detail' poll.id %}">{{ poll.question }}</a></li>
{% url %}标签会根据”polls.detail”在mysite/urls.py文件中寻找namespage=”polls”的相应URL,假如poll.id变量为5,演化后的实际代码想象中就是:
<li><a href="项目根目录/polls/5/">{{ poll.question }}</a></li>
这样做另外的好处是,避免了在template中硬编码URL,这也是django编程中要注意的要点(不要在模板中硬编码URL)
6.不要在模板中硬编码静态文件路径
不好的代码示范:
<img src="/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值,但是必须以斜线开始,否则找不到静态文件地址).STATIC_URL的目的即请求静态文件时,代表STATIC_ROOT. 所以,在开发阶段,Django会把STATIC_URL映射到django.contrib.staticfiles,staticfiles自动地从STATICFILES_DIRS和各个App的static子目录里面搜索静态文件. 在布署到生产环境的时候,则需要配置Apache(/etc/apache2/apache2.conf),把STATIC映射到STATIC_ROOT(Alias /static /home/usrname/projectname/static/).
STATICFILES_DIRS: 除了各个app的static目录以外,其他还需要管理的静态文件设置.
优化后的代码:
<img src="{{ STATIC_URL }}/images/test.png">{{ poll.question }}</img>
或者
{% load staticfiles %}
<img src="{% static "my_app/myexample.jpg" %}" alt="My image"/>
7.只加载一次自定义的模板标签
当需要使用自定义或者第三方的模板标签和模板过滤器时,通常要在模板中使用如下代码:
{% load cms_tags %}
实际情况是,需要在所有用到自定义模板标签和模板过滤器的模板中都使用上面的代码.
为了DRY, 优化后的解决办法是:将以下代码加到项目启动时能加载的文件中(setting.py、urls.py文件 etc.)
from django import template
template.add_to_builtins('cms.templatetags.cms_tags')
8. 了解一些第三方应用
a. 数据迁移 —— South(很好用,推荐)
常用命令:
python manage.py schemamigration youappname –initial
python manage.py schemamigration youappname --auto #检测对models的更改
python manage.py migrate youappnam
python manage.py syncdb
b. Django Debug ——Django-debug-toolbar
使用Django时需要注意的八个要点的更多相关文章
- Django 系列博客(八)
Django 系列博客(八) 前言 本篇博客介绍 Django 中的模板层,模板都是Django 使用相关函数渲染后传输给前端在显式的,为了想要渲染出我们想要的数据,需要学习模板语法,相关过滤器.标签 ...
- gunicorn启动django时静态文件的加载
目前在用nginx+gunicorn对django进行部署 当我用gunicorn -w 4 -b 127.0.0.1:8080 myproject.wsig:application启动django时 ...
- [Django基础] gunicorn启动django时静态文件的加载
目前在用nginx+gunicorn对django进行部署 当我用gunicorn -w 4 -b 127.0.0.1:8080 myproject.wsig:application启动django时 ...
- 解决nginx+uWSGI部署Django时遇到的static文件404的问题
昨天是利用Django自带的runserver部署的服务器,但是由于runserver比较不稳定,因此决定采用uWSGI+nginx进行部署. 昨天已经安装好了uwsgi和nginx,使用该指令打开8 ...
- 安装Django时解决的问题-mysql及访问(附pycharm激活)
1.做些软链接和virtualenv的基本使用: ln -s /data/linkdood/im/vrv/python36/bin/python3.6 /usr/bin/python3 ln -s / ...
- 使用mysql连接django时,需要的步骤以及错误解决办法
django默认使用的sqlite3,更改为SQL时需要按照如下操作进行 1.在settings.py中的78行进行更改 DATABASES = { 'default': { 'ENGINE': 'd ...
- Django框架(二十八)—— Django缓存机制
目录 Django缓存机制 一.什么是缓存 二.Django的6中缓存方式及配置(只需要改配置文件) 1.开发调试缓存(此模式为开发调试使用,实际上不执行任何操作) 2.内存缓存(将缓存内容保存至内存 ...
- Linux - 运行 django 时 :django.db.utils.Notsupportederror: urls not supported
运行 django 是异常:django.db.utils.Notsupportederror: urls not supported 原因:sqlite3版本3.7的问题 解决:直接改源码 1. p ...
- dapi 基于Django的轻量级测试平台八 Docker部署
QQ群: GitHub:https://github.com/yjlch1016/dapi 采用Docker+Supervisor+Nginx+uWSGI+Django 一.Dockerfile文件: ...
随机推荐
- AS的常见问题
版本问题 a.Gradle的版本 用于将代码和资源打包生成apk的编译脚本.此版本号究竟是啥得去studio的安装目录下查看b.Gradle插件的版本 com.android.tools.build: ...
- 我是如何同时拿到阿里和腾讯offer的 【转载】
前言 三月真是一个忙碌的季节,刚刚开学就需要准备各种面试和笔试(鄙视).幸运的是,在长达一个月的面试内推季之后,终于同时拿到了阿里和腾讯的offer,还是挺开心的.突而想起久未更新的博客,就冒昧学一学 ...
- Glide图片加载过程(简)
iceIC 关注 2018.10.25 20:53* 字数 906 阅读 529评论 0喜欢 1 调研版本为4.7.1为了更加简单的理解,会将函数代码简化,详细代码请自行照源码对比 Glide用法 G ...
- attribute__关键字举例之visibility
/** @file visibilityT.c * @note * @brief * @author * @date 2019-6-20 * @note v1.0.0 Created * @histo ...
- yarn那些事儿
本篇文章立足于mac. 一.安装yarn 1.通过homebrew brew update brew install yarn 2.通过脚本 curl -o- -L https://yarnpkg.c ...
- LODOP打印表格错位的几种情况
在网页设计中,表格经常用到百分比,表格在浏览器中展示,这个百分比是相对于浏览器的.还有div,各种浮动之类的相对位置,也有的用到百分比.而在LODOP打印中,百分比是相对于纸张的.LODOP中打印项的 ...
- 【linux学习笔记五】帮助命令
man //查看ls作用 man ls man -f命令 相当于 whatis命令 --help ls --help help help shell help cd info详细命令帮助
- Java基础教程:多线程基础(5)——倒计时器(CountDownLatch)
Java基础教程:多线程基础(5)——倒计时器(CountDownLatch) 引入倒计时器 在多线程协作完成业务功能时,有时候需要等待其他多个线程完成任务之后,主线程才能继续往下执行业务功能,在这种 ...
- 13、OpenCV实现图像的空间滤波——图像平滑
1.空间滤波基础概念 1.空间滤波基础 空间滤波一词中滤波取自数字信号处理,指接受或拒绝一定的频率成分,但是空间滤波学习内容实际上和通过傅里叶变换实现的频域的滤波是等效的,故而也称为滤波.空间滤波主要 ...
- nodejs ffi 调用dll
安装依赖 npm install --global --production windows-build-tools(在管理员权限打开的命令行中执行) npm install -g node-gyp ...