使用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文件: ...
随机推荐
- Flutter BottomSheet底部弹窗效果
BottomSheet是一个从屏幕底部滑起的列表(以显示更多的内容).你可以调用showBottomSheet()或showModalBottomSheet弹出 import 'package:flu ...
- Flutter Container容器组件、Text文本组件详解
import 'package:flutter/material.dart'; void main(){ runApp(MyApp()); } class MyApp extends Stateles ...
- 【转】Python常见web系统返回码
responses = { 100: ('Continue', 'Request received, please continue'), 101: ('Switching Protocols', ' ...
- WPF窗体自适应分辨率
使用WPF创建一个窗体(Window)时,如果设置了固定的高度(Height)和宽度(Width),一旦用户的电脑分辨率过低,就会使得窗体及其中的内容无法完整地显示出来.要解决这个这个问题,有以下几个 ...
- Locust性能测试-分布式执行的方法(亲测ok)
来源:https://www.cnblogs.com/yoyoketang/p/11681370.html 前言 使用Locust进行性能测试时,当一台单机不足以模拟所需的用户数量的时候,可以在多台机 ...
- SharpGL学习笔记(一) 平台构建与Opengl的hello World (转)
(一)平台构建与Opengl的hello World OpenGL就是3d绘图的API,微软针和它竞争推出D3D,也就是玩游戏时最常见的DirectorX组件中的3d功能. 所以不要指望windows ...
- layer confirm 三种选择按钮
layer.confirm('请选择是否通过提现?(tips:同意直接打款,驳回不可恢复)', { btn : ['通过-打款','不通过','通过-已打款'], btn1:function(){ a ...
- idea中maven项目下载源码的方式的
当我们打开class文件的时候,右上角有个Download Sources的超链接,点击就可以下载源码了. 下载源码后,就变成java文件了.
- shell脚本通过子网掩码计算出掩码位数
子网掩码格式为255.255.255.0可以通过以下脚本计算掩码位数 #!/bin/sh #maskdigits.sh mask maskdigits () { a=$(echo "$1&q ...
- Node.js学习笔记(4):Yarn简明教程
Node.js学习笔记(4):Yarn简明教程. 引入Yarn NPM是常用的包管理工具,现在我们引入是新一代的包管理工具Yarn.其具有快速.安全.可靠的特点. 安装方式 使用npm工具安装yarn ...