django基础(四)详解Views视图层

一、views基础知识

  1. 在django的MTV架构中,所谓视图层其实是进行业务处理(包括接受和响应http请求)的。整一个django的工作流程是这样子的:
    Alt text
    功能可以总结为:
  • 收到HTTP Request,执行URL映射
  • 根据URL映射调用视图函数,调用模型层数据
  • 渲染模版层网页文件,并生成HTTP Response返回。

二、基本URL映射功能

  1. urls.py需要包含的内容
from django.conf.urls import url
from django.contrib import admin
from appname.views import viewfunctionName
urlpatterns=[
	url(r'^admin',admin.site.urls),
	url(r'^$','welcome',name="welcome")
]
  1. url映射中的正则表达式
  • ^:托字符,表示首部
  • $:表示尾部
  • x | y:表示x或者y,例如request|reply,匹配request或者reply
  • [xyz]:字符集,匹配字符集内的任意单个字符,例如这里匹配x、y或z中的一个。
  • [^xyz]:不匹配字符集中的任意一个字符
  • [ - ]:字符或者数字的范围,例如[0-9]表示匹配从0到9的数字
  • {n}:匹配在它前面的单个字符n次,例如[0-9]{4}表示匹配长度为4个字符长度的数字
  • .:匹配除了换行符之外的任意单个字符
  • *:匹配在它前面的单个字符出现0次至任意多次的字符串,例如*a匹配""aaaaaaaaaa等。
  • .*:匹配除了换行符之外的任意字符串
  • +:匹配在它前面的单个字符出现至少一次的字符串。
  • \w:等价于[A-Za-z0-9]
  • \W:等价于[^A-Za-z0-9]
  • \d:等价于[0-9]
  • \d+:等价于[0-9]+
  • \D:等价于[^0-9]

例如:

  • url(r^$,welcome):匹配http://127.0.0.1:8000/
  • url(r^index,index):匹配http://127.0.0.1:8000/index1http://127.0.0.1:8000/index2http://127.0.0.1:8000/index3以及http://127.0.0.1:8000/index
  • url(r^index$,welcome):严格匹配http://127.0.0.1:8000/index

三、扩展URL映射功能

3.1 反向URL映射

我们经常需要在视图层和模版层中调用views函数以进行跳转。所以我们需要通过如下方式来达到这个目的:

  • 通过name属性为url条目设置名称(urlname)。
  • template中可以调用views函数(在template模板文件中通过{% url 'urlname' %})这种方式来调用。
  • views中也可以调用经过url映射的view函数,通过在views.py中用reverse('urlname')这种方法映射到其他对应的views函数。

案例1,在模版层调用views函数:
在urls.py中:
url(r'^$',welcome,name="welcomeurl")
url(r'^index',index,name="indexurl")
在welcome.html中若要调用index这个views函数
<a href="{% url'index' %}">进入主页</a>

案例2,在视图层调用其他views函数:
在urls.py中:
url(r'^list',list,name="listurl")
在views.py的其他函数中:
return HttpResponseRedirect(reverse('listurl'))

3.2 带命名参数的URL映射

基于命名传递给views函数/类。
语法规则:?P<param_name>pattern,即参数名+匹配模式(正则表达式)。
案例:
在urls.py中:
url(r'^news/(?P<news_id>\d+)/$',InterDatailView.as_view())
在views.py中的InterDataView类中:

def get(self,request,news_id):
	news=Newsdb.objects.get(id=int(news_id))
#根据新闻id获取新闻内容
3.3 分布式URL映射

在大型项目中,会存在有多个app和第三方插件的情况。这时候应该分别为不同的app设置单独的urls.py文件并在主urls.py中引用,这样更加方便管理。

  1. 多个app共存的url映射配置:
  • 新建一个工程。
  • manage.py startapp app1;manage.py startapp app2。
    enter image description here
  • 为每个app中新建urls文件。
    为每个app中新建urls文件
  • 在外部的urls.py中引入各app的url映射文件
#urls.py
urlpatterns = [
	url(r`^admin/`,include(admin.site.urls)),
	url(r'^app1/',include('app1.urls')),
	url(r'^app2/',include('app2.urls')),
]
  • 在settings.py中注册两个app
#settings.py
INSTALLED_APPS = (
 'django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'app1',
 'app2'
)
  • 建立共同引用的commontemplates与commonstatic文件
    enter image description here
  • 在setting中配置static与template
#settings.py

HERE = os.path.dirname(os.path.dirname(__file__))
MEDIA_ROOT = os.path.join( HERE ,'media').replace('\\','/') 
MEDIA_URL = '/media/' 
STATIC_ROOT = os.path.join(HERE,'static').replace('\\','/')
STATIC_URL = '/static/'
STATICFILES_DIRS = (
 # add other path no app static 
 os.path.join(HERE,'commonstatic/').replace('\\','/'),
)
#settings.py

TEMPLATES = [
 {
 'BACKEND': 'django.template.backends.django.DjangoTemplates',
 'DIRS': [(os.path.join(BASE_DIR, 'commontemplates')),],
 'APP_DIRS': True,
 'OPTIONS': {
  'context_processors': [
  'django.template.context_processors.debug',
  'django.template.context_processors.request',
  'django.contrib.auth.context_processors.auth',
 'django.contrib.messages.context_processors.messages',
  ],
 },
 },
  1. app/插件配置
url(r'audio/(?P<key>\w+)/$',vies.captcha_audio,name='captcha-audio')

四、视图函数

4.1 简介
  1. web服务器接受到用户发出的HTTP Request后,django执行url映射,然后把接下来的解析过程交给视图函数来处理。
  2. 视图函数大多数情况下会调用模型层的数据,并渲染Template网页,最终返回给用户(HTTP Response)
4.2 常用的视图函数
  • render:返回html文件并传递参数,例如:return render(request,"welcome.html",{'nowtime':nowtime})
  • HttpResponse:直接返回内容,例如return HttpResponse('<h1>你当前通过get方法访问该页面</h1>')
  • HttpResponseRedirect:重定向到另外的页面,状态码是302,例如:return HttpResponseRedirect(reverse("friendurl")),这里还用到了反向解析url映射。
  • HttpResponseNotFound:返回404状态码。
  • HttpResponseServerError:返回500状态码。
4.3 基于函数的写法
def friend(request):
        all_friend =  friendDB.objects.all()
        if request.method == "POST":
            if request.POST['checkfriendname']:
                checkfriendname = request.POST.get('checkfriendname')
                checkfriend = friendDB.objects.filter(friendName=checkfriendname)
                return render(request, 'friend.html', {"thisfriend": checkfriend,"all_friend": all_friend})
            else:
                deltefriend = request.POST.get('deltefriend')
                friendDB.objects.filter(friendName=deltefriend).delete()
                return render(request, 'friend.html', {"all_friend": all_friend})
        else:
            return render(request, 'friend.html', {"all_friend": all_friend})

但实际上,若处理的页面中有多个可以产生POST请求的按钮,应该采用下面这种形式来处理。
Alt text

4.4 基于类的写法

View类继承自django自带的基类base.View,自带get和post方法,可以直接重构,也可以封装更多的方法。

class learnHttp(View):
    def get(self,request):
        # requestInf = {
        #     "path": request.path,
        #     "method": request.method,
        #     "GET": request.GET,
        #     "POST": request.POST,
        #     # "COOKIES": request.cookies,
        #     # "FILES": request.files,
        #     "META": request.META,
        #     "user": request.user,
        #     "session": request.session,}
        #     # "raw_post_data": request.raw_post_data}
        return render(request,'learnDjango.html')

    def post(self,request):
        return render(request, 'learnDjango.html')
  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值