天天看点

django redirect传递参数_Django 视图层(四):视图函数 - views.py

django redirect传递参数_Django 视图层(四):视图函数 - views.py

介绍

一个

视图函数(类)

,简称视图,是一个简单的Python 函数(类),它接受Web请求并且返回Web响应。

响应可以是一张网页的HTML内容,一个重定向,一个404错误,一个XML文档,或者一张图片。

无论视图本身包含什么逻辑,都要返回响应。代码写在哪里也无所谓,只要它在你当前项目目录下面。

除此之外没有更多的要求了——可以说“没有什么神奇的地方”。为了将代码放在某处,大家约定成俗将视图放置在项目(project)或应用程序(app)目录中的名为views.py的文件中。

视图示例

下面是一个以HTML文档的形式返回当前日期和时间的视图:

from 
           

让我们来逐行解释下上面的代码:

  • 首先,我们从 django.http模块导入了HttpResponse类,以及Python的datetime库。
  • 接着,我们定义了current_datetime函数。它就是视图函数。每个视图函数都使用HttpRequest对象作为第一个参数,并且通常称之为request。 注意 :视图函数的名称并不重要;不需要用一个统一的命名方式来命名,以便让Django识别它。我们将其命名为current_datetime,是因为这个名称能够比较准确地反映出它实现的功能。
  • 这个视图会返回一个HttpResponse对象,其中包含生成的响应。每个视图函数都负责返回一个HttpResponse对象。

Django使用请求和响应对象来通过系统传递状态。

当浏览器向服务端请求一个页面时,Django创建一个HttpRequest对象,该对象包含关于请求的元数据。然后,Django加载相应的视图,将这个HttpRequest对象作为第一个参数传递给视图函数。

每个视图负责返回一个HttpResponse对象。

FBV和CBV

我们之前写过的都是基于函数的view,就叫FBV。还可以把view写成基于类的。

# urls.py中
url(r'^login.html$', views.Login.as_view()),

# views.py中
from django.views import View
class Login(View):
     
    def dispatch(self, request, *args, **kwargs):
        print('before')
        obj = super(Login,self).dispatch(request, *args, **kwargs)
        print('after')
        return obj
 
    def get(self,request):
        
        return render(request,'login.html')
 
    def post(self,request):
        print(request.POST.get('user'))
        return HttpResponse('Login.post')
           
使用CBV时要注意:

请求过来后会先执行dispatch()这个方法,如果需要批量对具体的请求处理方法,如get,post等做一些操作的时候,这里我们可以手动改写dispatch方法,这个dispatch方法就和在FBV上加装饰器的效果一样。

Django shortcut functions

Django shortcut functions​docs.djangoproject.com

django.shortcuts包含“跨越”多个MVC级别的辅助函数和类。本文只介绍视图层所使用到方法。

render()

render(request, template_name[, context])

结合一个给定的模板和一个给定的上下文字典,并返回一个渲染后的 HttpResponse 对象。

其默认的Content-Type标头设置为application/json。

参数:
     request: 用于生成响应的请求对象。

     template_name:要使用的模板的完整名称,可选的参数

     context:添加到模板上下文的一个字典。默认是一个空字典。如果字典中的某个值是可调用的,视图将在渲染模板之前调用它。

     content_type:生成的文档要使用的MIME类型。默认为 DEFAULT_CONTENT_TYPE 设置的值。

     status:响应的状态码。默认为200。
           

一个简单例子:

from django.shortcuts import render

def my_view(request):
    # 视图的代码写在这里
    return render(request, 'myapp/index.html', {'foo': 'bar'})
           

上面例子等同于:

from django.http import HttpResponse
from django.template import loader

def my_view(request):
    # 视图代码写在这里
    t = loader.get_template('myapp/index.html')
    c = {'foo': 'bar'}
    return HttpResponse(t.render(c, request))
           

redirect()

参数可以是:

  • 一个模型:将调用模型的 get_absolute_url() 函数
  • 一个视图,可以带有参数:将使用 urlresolvers.reverse 来反向解析名称
  • 一个绝对的或相对的URL,将原封不动的作为重定向的位置。

默认返回一个临时的重定向;传递

permanent=True

可以返回一个永久的重定向。

示例:

你可以用多种方式使用redirect() 函数。

传递一个对象(ORM相关)

将调用get_absolute_url() 方法来获取重定向的URL:

from django.shortcuts import redirect
 
def my_view(request):
    ...
    object = MyModel.objects.get(...)
    return redirect(object)
           

传递一个视图的名称:

def my_view(request):
     ...
     return redirect('some-view-name', foo='bar')
           

传递要重定向到的一个具体的网址:

def my_view(request):
     ...
     return redirect('/some/url/')
           

当然也可以是一个完整的网址:

def my_view(request):
     ...
     return redirect('http://example.com/')
           

默认情况下,redirect() 返回一个临时重定向。

以上所有的形式都接收一个permanent 参数;如果设置为True,将返回一个永久的重定向:

def my_view(request):
     ...
     object = MyModel.objects.get(...)
     return redirect(object, permanent=True)  
           
扩展阅读:

临时重定向(响应状态码:302)和永久重定向(响应状态码:301)对普通用户来说是没什么区别的,它主要面向的是搜索引擎的机器人。

A页面临时重定向到B页面,那搜索引擎收录的就是A页面。

A页面永久重定向到B页面,那搜索引擎收录的就是B页面。

继续阅读