博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django笔记-URLConf Views
阅读量:4053 次
发布时间:2019-05-25

本文共 5181 字,大约阅读时间需要 17 分钟。

一、库文件导入问题

1. from django.conf.urls.defaults import *

from website.contact.views import contact, thanks
#这种方法导入不好,因为随着views数量的增多,在每次加入
#新的view函数时还得确认是否已经导入了这个函数。
#如果项目非常大 则管理起来非常困难。
#另外导入语句过长也影响了代码的美观程度。

 

urlpatterns = patterns('',

 (r'^contact/$', contact),
 (r'^thanks/$', thanks),
 )
2. from django.conf.urls.defaults import *
#一种不需要导入函数的更好的写法
urlpatterns = patterns('website.contact.views',
#这种写法不需要导入view函数,django会自动导入需要的视图函数
#但是这里组要必须用字符串'contact’,而不是函数
 (r'^contact/$', 'contact'),
 (r'^thanks/$', 'thanks'),
 )

 

 

#如果多个共通头,还可以这样

urlpatterns = patterns('website.contact.views',
 (r'^contact/$', 'contact'),
 (r'^thanks/$', 'thanks'),
)

#if xxx:#在这里加上条件判断还可以有选择的将app加入到web中。

urlpatterns += patterns('website.blog.views',
 (r'^index/$', 'index'),
)
例如:
from django.conf import settings
from django.conf.urls.defaults import *
from mysite import views

urlpatterns = patterns('',

    (r'^$', views.homepage),
    (r'^(/d{4})/([a-z]{3})/$', views.archive_month),
)

if settings.DEBUG:

    urlpatterns += patterns('',
        (r'^debuginfo/$', views.debug),
    )

 

3. from website.contact.views import *

#* 表示,该模块的所有公共对象(public objects)都被导入到 当前的名称空间,
#也就是任何只要不是以”_”开始的东西都会被导入,views里面所有的代码,包括import的东
#西都会import的,所以这个方法是绝对不能用的。
urlpatterns = patterns('',
 (r'^contact/$', contact),
 (r'^thanks/$', thanks),
 )

 

4.from website.contact import views

#推荐方法,这个更pyhtonic
#而且控制起来也方便。
from website.contact import views
urlpatterns = patterns('',
 (r'^contact/$', views.contact),
 (r'^thanks/$', views.thanks),
 )

 

二、给views函数传递参数 

1.传递参数的两种方法

1)Using Named Groups, non-named regular expression groups

也叫Keyword Arguments vs. Positional Arguments。位置参数和关键字参数
2)Passing Extra Options to View Functions(见本节2中的例子)
别名英语称呼:从正则表达式传递过来的参数Captured Values,从额外字典传递的参数Extra Options

 

2. 正则表达式可以用在URLconf中。

URLconf parameter可以起名字,也可以用位置参数传递给views函数。
这里的正则表达式没有啥特殊的,需要传递的参数用小括号括起来。有一点要注意,
定义参数名时用?P例如定义一月中的某一天 (?P<day>/d/d)

 

3.不把变量放在URL中

如下所述bar_view同foo_view处理内容是相同的,只是模板不同而已,下面例子中
变量不用放在网址中即可显示不同的参数。即网址r'^foo/$'的变动不会影响处理。
该方法在某些方面用起来非常方便,最好的例子应该是generic views system的应用了。

# urls.py

from django.conf.urls.defaults import *
from mysite import views

urlpatterns = patterns('',

    (r'^foo/$', views.foobar_view, {'template_name': 'template1.html'}),
    (r'^bar/$', views.foobar_view, {'template_name': 'template2.html'}),
)

# views.py

from django.shortcuts import render_to_response
from mysite.models import MyModel

def foobar_view(request, template_name):

    m_list = MyModel.objects.filter(is_new=True)
    return render_to_response(template_name, {'m_list': m_list})   
3.字典参数传递的变量比正则表达式变量优先级高
例子:
urlpatterns = patterns('',
    (r'^mydata/(?P<id>/d+)/$', views.my_view, {'id': 3}),
)

虽然请求url中值为22 , 但是传递的ID参数为3

 

三、URLPattern技巧 

1.不要将URL逻辑处理放在Views中

URL是多变的,views的处理最好不要包含URL逻辑的处理。

不多说,看下面的例子:
urlpatterns = patterns('',
 #...........
 ('^auth/user/add/$', views.user_add_stage),#1
 ('^([^/]+)/([^/]+)/add/$', views.add_stage),#2
 #..........
显然,#2模式是包括#1的URL的,但是,这里/auth/user/add这个
网址需要特殊处理,如果是在views中处理应该是这样子的。显然
如果对应的URL变化了,views函数很快就不适应了。所以这样子不好。
def add_stage(request, app_label, model_name):
    if app_label == 'auth' and model_name == 'user':
        # do special-case code
    else:
        # do normal code

  (r'^somepage/$', views.method_splitter, {'GET': views.some_page_get, 'POST': views.some_page_post}),

    # ...

 

2.封装view函数

如下面代码,很冗余
d
ef my_view1(request):
    if not request.user.is_authenticated():
        return HttpResponseRedirect('/accounts/login/')
    # ...
    return render_to_response('template1.html')

def my_view2(request):

    if not request.user.is_authenticated():
        return HttpResponseRedirect('/accounts/login/')
    # ...
    return render_to_response('template2.html')

def my_view3(request):

    if not request.user.is_authenticated():
        return HttpResponseRedirect('/accounts/login/')
    # ...
    return render_to_response('template3.html')

 

么样把他简化呢?看下面这个封装函数

def requires_login(view):
    def new_view(request, *args, **kwargs):
        if not request.user.is_authenticated():
            return HttpResponseRedirect('/accounts/login/')
        return view(request, *args, **kwargs)
    return new_view

 

经过封装后,代码可以极大的简化,URLPattern应该是这个样子

from django.conf.urls.defaults import *
from mysite.views import requires_login, my_view1, my_view2, my_view3

urlpatterns = patterns('',

    (r'^view1/$', requires_login(my_view1)),
    (r'^view2/$', requires_login(my_view2)),
    (r'^view3/$', requires_login(my_view3)),
)

 

四、包含其他URLConfs

1.gotcha

用include的正则表达式,不能包含$来表示结尾,另外结尾必须有/
例如:"r^/http/" -OK       "r^/http/$"NG
 
2.参数传递
如果被包含的urls接受了一个参数,那么他会传递给任意一个include里面
的views函数。

同样 Extra URLconf Options 也会传递下层被包含的每一个url中。

例子:下面的两个是等同的。

Set one:

# urls.py
from django.conf.urls.defaults import *
urlpatterns = patterns('',
    (r'^blog/', include('inner'), {'blogid': 3}),
)
# inner.py
from django.conf.urls.defaults import *
urlpatterns = patterns('',
    (r'^archive/$', 'mysite.views.archive'),
    (r'^about/$', 'mysite.views.about'),
    (r'^rss/$', 'mysite.views.rss'),
)
##############################################################
Set two:
# urls.py
from django.conf.urls.defaults import *
urlpatterns = patterns('',
    (r'^blog/', include('inner')),
)
# inner.py
from django.conf.urls.defaults import *
urlpatterns = patterns('',
    (r'^archive/$', 'mysite.views.archive', {'blogid': 3}),
    (r'^about/$', 'mysite.views.about', {'blogid': 3}),
    (r'^rss/$', 'mysite.views.rss', {'blogid': 3}),
)

<本节完>

转载地址:http://vzxci.baihongyu.com/

你可能感兴趣的文章
yuv420 还原为RGB图像
查看>>
LED恒流驱动芯片
查看>>
驱动TFT要SDRAM做为显示缓存
查看>>
使用file查看可执行文件的平台性,x86 or arm ?
查看>>
qt 创建异形窗体
查看>>
简单Linux C线程池
查看>>
内存池
查看>>
Qt继电器控制板代码
查看>>
wpa_supplicant控制脚本
查看>>
gstreamer相关工具集合
查看>>
RS232 四入四出模块控制代码
查看>>
linux 驱动开发 头文件
查看>>
container_of()传入结构体中的成员,返回该结构体的首地址
查看>>
ipconfig,ifconfig,iwconfig
查看>>
opensuse12.2 PL2303 minicom
查看>>
网络视频服务器移植
查看>>
Encoding Schemes
查看>>
移植QT
查看>>
如此调用
查看>>
计算机的发展史
查看>>