flask中的CBV和FBV

flask中CBV使用

from flask import Flask, views

app = Flask(__name__)

class Login(views.MethodView):
    methods = ['POST', 'GET']
    # 如果需要在CBV中加装饰器的话,括号里就是装饰器的内存地址,可以传多个
    decorators = ()

    def get(self):
        print('get 请求')
        return 'login get'

    def post(self):
        print('post 请求')
        return 'login post'

app.add_url_rule('/login', view_func=Login.as_view(name='login'))

if __name__ == "__main__":
    app.run(debug=True)

Login.as_view(name=‘login‘) 先对这段代码就行解析吧

Login : 它是我们写一个视图类对吧

as_view : 由类直接调用,他应该就是类里的一个函数(这里看不错它是对象方法,还是类方法,还是静态方法),

因为类可以调用它下面的所有函数对吧,在我们的Login 并没有写as_view 这个函数,所以这个函数应该在它继承的类中,我们顺着这个基类去找找看,最终我们在View这个类中找到

它做了下面这几件事:

  1. 最开始定义了一个view函数
  2. 再判断cls.decorators ,这里的cls就是我们所定义的视图类Login ,假如我们视图类没有写decorators 这个属性,那么最终会在View这个类中找到该属性,默认为一个空元组,所以说布尔值默认False,如果我们在自定义的试图类中假如的装饰器,也就是说decorators 它是有值的,一个元组或列表,最终会for循环decorators 的值,并一层一层的包裹,所以你写的装饰器顺序是需要注意下的
  3. 然后就是给view 函数赋值操作了,python中一切皆对象,所以这个函数也是一个对象
  4. 最后返回了定义的view 函数的内存地址
  5. 那么我们在创建路由和视图关系那里,也就是这条app.add_url_rule(‘/login‘, view_func=Login.as_view(name=‘login‘)),其中的view_func 应该是view的内存地址了
  6. 最后就会执行app.add_url_rule 这个函数,这个函数才会创建号路由视图之间的关系

提醒一点:

  1. 在上面的app.add_url_rule 这个方法里,我并没有写endpoint 这个属性,那么最终会以view_func 所对应的函数的__name__ 方法作为endpoint 的值,那么我上面代码的基础上再写一个Register的视图函,再创建一个路由试图关系,也就是执行app.add_url_rule,他们的view_func对应的都是view函数的内存地址,你说会不会报错呢?

    答案:是不会报错的,因为你在as_view方法里传了一个name的参数,其实这个name相当于就是endpoint,所以这个name 你是不可以相同的,在as_view方法里,它有这样的一步操作view.__name__=name ,所以返回的view__name__ 的值是不同的。

那么来了一个请求,它的url是/login ,然后这个视图类中是怎么执行的呢?

  1. 首先我们创建路由关系,比如这样的 "/login" -->> (这是允许请求的方法) -->> login(记住这是endpoint的值,其实他真正对应的是view这个函数的内存地址)
  2. 请求来了,便会去执行这个view 函数

    view.view_class :就是Login视图类,那么self就是Login的实例对象

    最终返回了 self.dispatch_request(*args, **kwargs)这个方法的返回值

  3. 很明显我们写的Login 视图类中没有dispatch_request这个方法,那么我们继续在它的基类里寻找,最终在MethodView这个基类里找到了

    1. request.method.lower() 就是这次请求的方法,self 就是Login的实例对象,

      通过getattr获取到以请求方法小写的方法的内存地址。这里根本没有判断该视图类允许的请求方法,所以说我在写视图类的时候,methods这个属性是不是可以不用写呢?等下我去试试

    2. 然后就是一系列的判断,断言什么的,很容易看懂就不说了
    3. 最终是执行了meth这个方法,将它的返回值返回回去
    4. 所以说view这个函数的返回值,也就是meth的返回值

总结下CBV:

  1. 写一个定义CBV流程:

    1. 首先导入views,`from flask import views
    2. 自定义一个视图类,并且继承Views.MethodView
    3. 如果你要给你的视图类加装饰器的话,在该视图类中写decorator ,它是一个列表,你把装饰器函数的内存地址写进去好了
    4. 然后根据不同的请求,写相应的方法,比如对get请求写相关的方法,def get(self):pass 就好了,其他请求方法都是一个
    5. 最后配置好路由和视图函数之间的关系就好了

      app.add_url_rule(‘路径‘,view_func=视图类.as_view(name=‘一般就以视图类名小写吧,总之不能有重名‘))

  2. 写执行CVB的流程
    1. 一个请求来了,通过url找到相应的view函数,加括号执行
    2. 再执行dispatch_request方法
    3. 通过本次请求的方式名小写,获取到视图类对应的方法名
    4. 执行该方法,最终将返回值返回。

flask中FBV

没啥好讲的,写段FVB的代码吧

from flask import Flask

app = Flask(__name__)

@app.route('/index')
def index():
    return "index page"

if __name__ == "__main__":
    app.run(debug=True)

原文地址:https://www.cnblogs.com/zhuchunyu/p/10466512.html

时间: 2024-11-05 02:17:12

flask中的CBV和FBV的相关文章

Django中的CBV和FBV

Django中的CBV和FBV 一.  CBV CBV是采用面向对象的方法写视图文件. CBV的执行流程: 浏览器向服务器端发送请求,服务器端的urls.py根据请求匹配url,找到要执行的视图类,执行dispatch方法区分出是POST请求还是GET请求,执行views.py对应类中的POST方法或GET方法. 使用实例: urls.py path('login/',views.Login.as_view()) views.py from django import views #在views

flask中的CBV , flask-session在redis中存储session , WTForms数据验证 , 偏函数 , 对象里的一些小知识

flask中的CBV , flask-session在redis中存储session , WTForms数据验证 , 偏函数 , 对象里的一些小知识 flask中的CBV写法 后端代码 # 导入views from flask import Flask, render_template, views, request app = Flask(__name__) # CBV写法 class Login(views.MethodView):       # 定义一个类,不用装饰器,继承了Method

Django的CBV和FBV

1. Django支持两种对应关系,CBV和FBV FBV:function base view &CBV:class base view  url.py    index---函数名  views.py    def 函数(request): /index/ -> 函数名 /index/ ->类,请求来了以后,会执行类里面的指定的方法. 2.CBV提交----- class Home(view) Home类必须继承view. 2.1 urls.py中写对应关系 2.2 views.p

django中的CBV

CBV介绍 我们在写一个django项目时,通常使用的都是FBV(function base views) 而CBV(class base views)也有它自己的应用场景,比如在写一个按照rest规范写接口时,CBV的适用性就比FBV更强 先来看看CBV在django中的写法,与FBV有什么不同的地方 url(r'^students/', views.StudentsView.as_view()) 路由 from django.views import View class StudentsV

django补充CBV和FBV模式

django补充CBV和FBV模式FBV模式---函数:经常用的方式CBV模式---类CBV中url连接时函数名后面要接.as_view()class index(views.View): @... def dispath(self,request,*arg,**kwarg): super...如果对某一种请求做处理:单一装饰器如果对请求做处理:dispatch单一装饰器注:CBV模式中的装饰器要调用method_decoratorfrom django.utils.decorators imp

Flask中使用mysql

Flask中使用mysql 先安装相关模块: pip  install  Flask-MySQL 先准备一下数据库 登录: mysql  -u  root  -p 创建Database和创建Table mysql> CREATE DATABASE EmpData; mysql> use EmpData; mysql> CREATE TABLE User( userId INT NOT NULL AUTO_INCREMENT, userName VARCHAR(100) NOT NULL,

flask中'bool' object has no attribute '__call__'问题

#写flask时报错 <ul class="nav navbar-nav"> <li><a href="/">Home</a></li> </ul> </div> <ul class="nav navbar-nav navbar-right"> {% if current_user.is_authenticated() %} <li><

解决Flask中文件操作出现UnicodeDecodeError UnicodeDecodeError: &#39;ascii&#39; codec can&#39;t decode byte 0xe6 in positio

写一个Flask应用的功能时需要读文件,文件内容含指定字符串的话(即有个if key in filecontent的比较)就把文件内容输出到页面,,结果报错UnicodeDecodeError,查阅Flask的文档却似乎讲Flask默认哪里都是utf8编码,可现在却出了个由于字符是utf8而不是ascii报的错 最后解决了 我灵机一点把filecontent解码一下,写成filecontent.decode('utf8'),就顺利的运行了 版权声明:本文为博主原创文章,未经博主允许不得转载. 解

Flask中处理依赖的技巧

Flask应用中通常会用工厂模式 来创建应用对象,这样方便配置和测试.现在我们就用实例来学习Flask的处理依赖 应用代码 # app/__init__.pyfrom flask import Flaskfrom flask_xxxext import Xxxfrom flask_yyyext import Yyy# ... 一些flask拓展xx = Xxx()yy = Yyy() def create_app(config=None): app = Flask(__name__) xx.in