Django를 이제 막 배우기 시작한 초보자라면 주목하세요. Django를 더 잘 배우고 실수를 줄이고 우회하는 데 도움이 되는 10가지 주의 사항을 살펴보세요~~
1. 참조 코드에 프로젝트 이름을 포함하지 마세요.
예를 들어 "project"라는 프로젝트를 생성하고 "app"이라는 애플리케이션을 포함하는 경우 다음 코드는 적합하지 않습니다.
from project.app.models import Author
단점은 애플리케이션과 프로젝트가 긴밀하게 결합되어 애플리케이션을 쉽게 재사용할 수 없다는 것입니다. 향후 프로젝트 이름을 변경해야 한다면 감수해야 할 것입니다.
권장되는 접근 방식은 다음과 같습니다.
from app.models import Author
PYTHONPATH에서 프로젝트 경로를 구성해야 합니다.
2. MEDIA_ROOT 및 TEMPLATE_DIRS를 하드코딩하지 마세요.
프로젝트 구성 파일 settings.py에 다음 코드를 사용하지 마세요.
TEMPLATE_DIRS = ( "/home/html/project/templates",) MEDIA_ROOT = "/home/html/project/appmedia/"
프로덕션 환경 또는 서버를 마이그레이션할 때 문제가 발생할 수 있습니다.
다음 방법을 사용하는 것이 좋습니다.
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와의 차이점은 http://rob.cogit8.org/blog/2009를 참조하세요. /May/05/django-and -relativity-updated/ )
3. 템플릿에 정적 파일의 경로를 하드코딩하지 마세요.
CSS, javascript 또는 이미지를 링크할 때 템플릿의 경우 다음 방법을 사용하지 않는 것이 좋습니다.
<link rel="stylesheet" type="text/css" href="/appmedia/amazing.css" /> <script type="text/javascript" src="/appmedia/jquery.min.js"></script>
프로젝트에 다른 서버에서 정적 파일을 제공해야 하는 경우 일반적으로 다른 http 주소가 되며 모든 /appmedia를 바꿔야 합니다. / 새 주소를 가지고 웹사이트에 대한 코드를 작성하는 것만으로도 충분히 지루합니다.
걱정할 필요 없는 해결책은 하드 코딩된 경로 대신 {{ MEDIA_URL }}을 사용하는 것입니다.
<link rel="stylesheet" type="text/css" href="{{ MEDIA_URL }}amazing.css" /> <script type="text/javascript" src="{{ MEDIA_URL }}jquery.min.js"></script>
템플릿 컨텍스트 변수를 얻는 방법은 무엇입니까? RequestContext를 사용하세요:
return render_to_response("app/template.html", {'var': 'foo'}, context_instance=RequestContext(request))
RequestContext에서 현재 사용자 및 기타 정보를 가져올 수도 있습니다
4. 뷰에 비즈니스 로직 코드를 작성하지 마세요
views.py에 논리를 작성하는 많은 책과 예제를 읽었더라도 혼동하지 마세요. 이는 단위 테스트 및 코드 재사용에 도움이 되지 않기 때문입니다.
그렇다면 비즈니스 로직을 어디에 배치해야 할까요? 모델에 넣거나 별도의 헬퍼 모듈을 생성하는 것이 좋습니다.
물론 모델에서 작성자를 가져오려면 작성자 목록을 가져오는 코드를 뷰에 배치할 수 있습니다.
5. 배포 시 DEBUG를 False로 설정하는 것을 잊지 마세요
배포 중에 DEBUG를 비활성화하는 것을 종종 잊어버립니다.
import socket if socket.gethostname() == 'productionserver.com': DEBUG = False else: DEBUG = True
또 다른 방법은 다른 구성 파일을 사용하는 것입니다.
#文件名:settings_debuy.py #包含调试模式的配置信息 #http://www.pythontab.com #使用python manage.py runserver settings=settings_debug.py来运行项目 from settings import * DEBUG = True #还可以配置更多在调试时使用的变量:)
6. 맞춤 템플릿 태그를 한 번만 로드하세요.
맞춤 템플릿 또는 타사 템플릿을 사용해야 하는 경우 템플릿 태그와 템플릿 필터는 일반적으로 템플릿에서 사용됩니다.
{% load template_tags %}
실제 상황은 위의 코드가 사용자 정의 템플릿 태그와 템플릿 필터를 사용하는 모든 템플릿에서 사용해야 하므로 더 이상 DRY가 아닙니다.
from django import template template.add_to_builtins('app.templatetags.custom_tag_module')
프로젝트 시작 시 로드할 수 있는 모듈(settings.py, urls.py, models.py 등)에 위 코드를 넣어주세요.
위 코드의 기능은 프로젝트가 시작될 때 사용자 정의 템플릿 태그나 필터를 로드하는 것입니다. 이는 {% load template_tags %} 없이 템플릿 내 어디에서나 사용할 수 있습니다.
7. URL을 적절하게 구성하고 사용하세요.
다음과 같이 하나의 urls.py 파일에 모든 URL을 구성하지 마세요.
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"), , )
권장되는 방법은 각각을 구성하는 것입니다. 애플리케이션 URL은 해당 urls.py에 구성되어 있어 애플리케이션을 다른 프로젝트에서 더 쉽게 재사용할 수 있습니다.
urlpatterns = patterns('', (r'^$', include('institution.urls')), (r'^institution/', include('institution.urls')), (r'^askalumini/', include('askalumini.urls')), (r'^member/', include('member.urls')), )
다음은 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") )
방금 언급했듯이 정적 파일 경로는 하드 코딩되어서는 안 되며, URL 처리 방법도 하드 코딩되어서는 안 됩니다. 그렇지 않으면 주소를 변경할 때 일부 URL 기능을 사용할 수 있습니다. 그것을 처리하기 위해.
/project/askalumini/urls.py에는 각 URL에 이름이 정의되어 있어 하드 코딩 대신 뷰, 템플릿, 모델에서 URL을 효과적으로 처리하는 데 도움이 됩니다.
이름의 고유성을 보장하려면 URL 이름을
예를 들어 views.py 파일에 다음 코드가 있습니다.
HttpResponseRedirect("/askalumini/questions/54")
다음으로 변경하세요.
from django.core.urlresolvers import reverse HttpResponseRedirect(reverse('askquestiondisplay',kwargs={'questionno':q.id}))
모델 사용 url 형식을 지정하는 모델 .permalink 데코레이터:
@models.permalink def get_absolute_url(self): return ('profileurl2',(),{'userid': self.user.id})
하드코딩 대신 템플릿에 url 태그 사용:
{% url askquestiondisplay 345 %} <a href="{% url askquestiondisplay 345 %}"> Ask Question </a>
8,调试
调试通常会借助一些第三方工具来获得更多的运行时信息。
一个请求执行了多少句SQL?花了多长时间?
调用的哪个模板?客户端设置了什么COOKIE?SESSION呢?。。。
你可以使用django-debug-toolbar查看上面甚至更多的信息
另一个工具是Werkzeug debugger,它可以在错误页面打开python shell,让你更方便的跟踪错误信息
还有pdb,一个强大的调试工具:http://ericholscher.com/blog/2008/aug/31/using-pdb-python-debugger-django-debugging-series-/
9,了解pinax备用
django最大的优点是代码重用,DRY,pinax就是这样一个平台,包含了许多可拿来直接使用的代码,比如openid,电子邮件验证等等。请访问:http://pinaxproject.com/
10,了解一些有用的第三方应用
1)数据库升级工具
什么是数据库升级工具?你运行了syncdb,运行了一年之后,对模型做了更改,添加了字段,删除了字段,要再运行syncdb吗?或者ALTER TABLE ...?
django-evolutions可以帮你完成上面的事情,但它好像不够强壮:http://code.google.com/p/django-evolution/
South能很强壮地完成上面的事情,但是需要学学怎么用:http://south.aeracode.org/
2)模板系统
django自带的模板系统是可以替换的,并且各自有优缺点。
template-utils增强了模板的比较标签等功能 ,并提供其他的一些实用特性
Jinja是一个完整的第三方模板系统,可以替换默认模板系统,它提供了许多优越的特性
3)第三方应用
django command extensions提供了很多实用的命令行功能:
shell_plus加载所有django模型
runserver_plus整合了Werkzeug调试工具
生成模型图表,你可以展示给你的老板
……