最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

新手學(xué)習(xí)Django的十條注意點(diǎn)

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 14:28:41
文檔

新手學(xué)習(xí)Django的十條注意點(diǎn)

新手學(xué)習(xí)Django的十條注意點(diǎn):剛剛開始學(xué)習(xí)Django的新手注意了,這里總結(jié)了十條注意點(diǎn),能夠幫助你更好的學(xué)習(xí)Django,減少出錯(cuò),避免走彎路,很值得一看哦~~1,不要將項(xiàng)目名稱包含在引用代碼里比如你創(chuàng)建了一個(gè)名為"project"的項(xiàng)目,包含一個(gè)名為"app"
推薦度:
導(dǎo)讀新手學(xué)習(xí)Django的十條注意點(diǎn):剛剛開始學(xué)習(xí)Django的新手注意了,這里總結(jié)了十條注意點(diǎn),能夠幫助你更好的學(xué)習(xí)Django,減少出錯(cuò),避免走彎路,很值得一看哦~~1,不要將項(xiàng)目名稱包含在引用代碼里比如你創(chuàng)建了一個(gè)名為"project"的項(xiàng)目,包含一個(gè)名為"app"

剛剛開始學(xué)習(xí)Django的新手注意了,這里總結(jié)了十條注意點(diǎn),能夠幫助你更好的學(xué)習(xí)Django,減少出錯(cuò),避免走彎路,很值得一看哦~~

1,不要將項(xiàng)目名稱包含在引用代碼里
比如你創(chuàng)建了一個(gè)名為"project"的項(xiàng)目,包含一個(gè)名為"app"的應(yīng)用,那么如下代碼是不好的:

from project.app.models import Author

缺點(diǎn)在于:應(yīng)用和項(xiàng)目變成了緊耦合,無法將應(yīng)用輕易變得可重用。如果將來要換一個(gè)項(xiàng)目名稱,那你可有得受了。
推薦的做法是:

from app.models import Author

請(qǐng)注意,你需要將項(xiàng)目的路徑配置在PYTHONPATH中。
2,不要硬編碼MEDIA_ROOT和TEMPLATE_DIRS
項(xiàng)目配置文件settings.py中不要使用如下代碼:

TEMPLATE_DIRS = ( "/home/html/project/templates",) 
MEDIA_ROOT = "/home/html/project/appmedia/"

當(dāng)你在部署到生產(chǎn)環(huán)境,或者遷移服務(wù)器的時(shí)候,就會(huì)發(fā)生問題。
推薦使用如下方式:

SITE_ROOT = os.path.realpath(os.path.dirname(__file__)) 
MEDIA_ROOT = os.path.join(SITE_ROOT, 'appmedia') 
TEMPLATE_DIRS = ( os.path.join(SITE_ROOT, 'templates'),)

(也可以使用abspath,跟realpath的區(qū)別請(qǐng)參考http://rob.cogit8.org/blog/2009/May/05/django-and-relativity-updated/ )
3,不要將靜態(tài)文件的路徑硬編碼在模板中
模板中鏈接CSS,javascript或圖片的時(shí)候,不建議使用如下方式:

<link rel="stylesheet" type="text/css" href="/appmedia/amazing.css" />
<script type="text/javascript" src="/appmedia/jquery.min.js"></script>

當(dāng)你的項(xiàng)目需要將靜態(tài)文件用其他服務(wù)器提供的時(shí)候,通常會(huì)是另外一個(gè)http地址,那么你就得把所有的/appmedia/替換成新的地址,做網(wǎng)站寫代碼已經(jīng)夠乏味的了。
沒有后顧之憂的解決方法是使用{{ MEDIA_URL }}代替硬編碼的路徑:

<link rel="stylesheet" type="text/css" href="{{ MEDIA_URL }}amazing.css" />
 <script type="text/javascript" src="{{ MEDIA_URL }}jquery.min.js"></script>

模板上下文變量怎么獲取到呢?請(qǐng)使用RequestContext即可:

return render_to_response("app/template.html", {'var': 'foo'}, context_instance=RequestContext(request))

從RequestContext里還可以獲取到當(dāng)前用戶等信息

4,不要將業(yè)務(wù)邏輯代碼寫到視圖里

不要迷惑,雖然你可能看過很多書和例子,它們把邏輯都寫在了views.py里,但請(qǐng)你別這么做。因?yàn)檫@樣不利于單元測(cè)試,不利于重用代碼。
那我的業(yè)務(wù)邏輯應(yīng)該放哪里呢?推薦放到模型里或者單獨(dú)建立一個(gè)輔助(helper)模塊。
當(dāng)然,從模型得到一個(gè)Author,獲取Author列表的代碼是可以放到視圖里面的。
5,部署時(shí)別忘記將DEBUG設(shè)置成False
我們常常忘記在部署時(shí)禁用DEBUG,有很多種方法自動(dòng)來處理這個(gè)配置:

import socket 
if socket.gethostname() == 'productionserver.com': 
 DEBUG = False
else: 
 DEBUG = True

另一種途徑是使用不同的配置文件:

#文件名:settings_debuy.py
#包含調(diào)試模式的配置信息
#http://www.pythontab.com
#使用python manage.py runserver settings=settings_debug.py來運(yùn)行項(xiàng)目
from settings import *
DEBUG = True
#還可以配置更多在調(diào)試時(shí)使用的變量:)

6,只加載一次自定義的模板標(biāo)簽
當(dāng)需要使用自定義或者第三方的模板標(biāo)簽和模板過濾器時(shí),通常要在模板中使用:

{% load template_tags %}

實(shí)際情況是,需要在所有用到自定義模板標(biāo)簽和模板過濾器的模板中都使用上面的代碼,這樣就不DRY了。

from django import template 
template.add_to_builtins('app.templatetags.custom_tag_module')

請(qǐng)將以上代碼放到項(xiàng)目啟動(dòng)時(shí)能加載的模塊中(settings.py, urls.py, models.py等)即可。

上面代碼的作用是在項(xiàng)目啟動(dòng)時(shí)就把自定義模板標(biāo)簽或過濾器加載進(jìn)來,模板中任何一個(gè)地方都可以使用它們,而不需要{% load template_tags %}。
7,合理配置和使用URL
不要將URL全都配置在一個(gè)urls.py文件中,比如:

urlpatterns = patterns('', 
 url(r'^askalumini/question/$','.....registerInstitution',name='iregister'), 
 url(r'^askalumin/answer/$','someview.....',name='newmemberurl'), 
 url(r'^institution/member/$','someview.....',name="dashboardurl"), 
 url(r'^institution/faculty/$','editInstitute',name="editinstituteurl"), 
 url(r'^memeber/editprofile/$','editProfile',name="editprofileurl"), 
 url(r'^member/changepassword/$','changePassword',name="changepasswordurl"), 
 url(r'^member/forgotpassword/$','forgotPassword',name="forgotpasswordurl"), 
 url(r'^member/changepicture/$','changePicture',name="changepictureurl"), 
 url(r'^member/logout/$','memeberlogout',name="logouturl"), , 
)

建議的方式是將各應(yīng)用的URL配置在各自的urls.py中,這樣可以使應(yīng)用更容易重復(fù)使用到不同項(xiàng)目里:

urlpatterns = patterns('', 
 (r'^$', include('institution.urls')), 
 (r'^institution/', include('institution.urls')), 
 (r'^askalumini/', include('askalumini.urls')), 
 (r'^member/', include('member.urls')), 
)

如下是應(yīng)用askalumini的urls.py:

urlpatterns = patterns('askalumini.views', 
 url(r'^$','askHome',name='askaluminiurl'), 
 url(r'^questions/(?P<questionno>d+)/$','displayQuestion',name='askquestiondisplay'), 
 url(r'^askquestions/$','askQuestion',name='askquestionurl'), 
 url(r'^postcomment/$','postComment',name="askquestioncomment") 
)

剛才提到靜態(tài)文件路徑不要硬編碼,url的處理方式也盡量不要硬編碼,否則當(dāng)你更改一個(gè)地址時(shí)會(huì)牽涉到多處的修改,可以使用一些url函數(shù)來處理。

在/project/askalumini/urls.py中,為每一個(gè)url定義了name,它可以幫助我們有效地在視圖、模板和模型中處理url,而不是硬編碼。
為保證名稱的唯一,請(qǐng)遵照將url命名為<appname>/<somelabel>的習(xí)慣用法。
舉例來說,在views.py文件中有如下代碼:

HttpResponseRedirect("/askalumini/questions/54")

請(qǐng)改為:

from django.core.urlresolvers import reverse 
HttpResponseRedirect(reverse('askquestiondisplay',kwargs={'questionno':q.id}))

在模型中使用models.permalink裝飾器來格式url:

@models.permalink 
def get_absolute_url(self): 
return ('profileurl2',(),{'userid': self.user.id})

在模板中使用url標(biāo)簽代替硬編碼:

{% url askquestiondisplay 345 %} 
<a href="{% url askquestiondisplay 345 %}"> Ask Question </a>

8,調(diào)試
調(diào)試通常會(huì)借助一些第三方工具來獲得更多的運(yùn)行時(shí)信息。
一個(gè)請(qǐng)求執(zhí)行了多少句SQL?花了多長(zhǎng)時(shí)間?
調(diào)用的哪個(gè)模板?客戶端設(shè)置了什么COOKIE?SESSION呢?。。
你可以使用django-debug-toolbar查看上面甚至更多的信息
另一個(gè)工具是Werkzeug debugger,它可以在錯(cuò)誤頁面打開python shell,讓你更方便的跟蹤錯(cuò)誤信息
還有pdb,一個(gè)強(qiáng)大的調(diào)試工具:http://ericholscher.com/blog/2008/aug/31/using-pdb-python-debugger-django-debugging-series-/
9,了解pinax備用
django最大的優(yōu)點(diǎn)是代碼重用,DRY,pinax就是這樣一個(gè)平臺(tái),包含了許多可拿來直接使用的代碼,比如openid,電子郵件驗(yàn)證等等。請(qǐng)?jiān)L問:http://pinaxproject.com/
10,了解一些有用的第三方應(yīng)用
1)數(shù)據(jù)庫升級(jí)工具
什么是數(shù)據(jù)庫升級(jí)工具?你運(yùn)行了syncdb,運(yùn)行了一年之后,對(duì)模型做了更改,添加了字段,刪除了字段,要再運(yùn)行syncdb嗎?或者ALTER TABLE ...?
django-evolutions可以幫你完成上面的事情,但它好像不夠強(qiáng)壯:http://code.google.com/p/django-evolution/
South能很強(qiáng)壯地完成上面的事情,但是需要學(xué)學(xué)怎么用:http://south.aeracode.org/
2)模板系統(tǒng)
django自帶的模板系統(tǒng)是可以替換的,并且各自有優(yōu)缺點(diǎn)。
template-utils增強(qiáng)了模板的比較標(biāo)簽等功能 ,并提供其他的一些實(shí)用特性
Jinja是一個(gè)完整的第三方模板系統(tǒng),可以替換默認(rèn)模板系統(tǒng),它提供了許多優(yōu)越的特性
3)第三方應(yīng)用
django command extensions提供了很多實(shí)用的命令行功能:
shell_plus加載所有django模型
runserver_plus整合了Werkzeug調(diào)試工具
生成模型圖表,你可以展示給你的老板
……

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

新手學(xué)習(xí)Django的十條注意點(diǎn)

新手學(xué)習(xí)Django的十條注意點(diǎn):剛剛開始學(xué)習(xí)Django的新手注意了,這里總結(jié)了十條注意點(diǎn),能夠幫助你更好的學(xué)習(xí)Django,減少出錯(cuò),避免走彎路,很值得一看哦~~1,不要將項(xiàng)目名稱包含在引用代碼里比如你創(chuàng)建了一個(gè)名為"project"的項(xiàng)目,包含一個(gè)名為"app"
推薦度:
標(biāo)簽: 新手 注意 新人
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top