最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Django2.2版本的新特性都有哪些

    正文概述    2020-10-11   243

    2019年4月1日,Django官方如期发布了2.2版本,这是一个LST版本,将持续维护和安全更新到2022年4月,也就是说至少有3年的生命周期,所以这是一个可以长期使用的版本。上一个LST版本Django1.11将在2020年4月停止维护。

    在这里不得不吐糟一下Django的版本升级路线,版本号提升得太快了!!2.2之后就是3.0,并且3.0会在2019年12月份正式发布,这给一些初学者或者小公司带来太多的困惑,不知道该学或者该用哪个版本了。个人建议Python2.7没得选,只能使用Django1.11版本。Python3.x的,直接选最新版本或者最近的LST版本,差别不大。

    Django2.2版本的新特性都有哪些

    2.2版本依然包含了一些新特新,和一些对前期版本不兼容的说明。

    Python兼容性

    Django2.2支持Python3.5、3.6和3.7。

    新特性

    约束

    新的CheckConstraint和UniqueConstraint类现在开始支持自定义数据库约束,通过使用Meta.constraints选项。

    小特性

    1. django.contrib.admin

    为TabularInline添加了列头的CSS类

    2. django.contrib.auth

    HttpRequest将被作为第一个位置参数传递给RemoteUserBackend.configure_user()方法。

    3. django.contrib.gis

    Envelope函数开始支持Oracle。 coveredby和covers查询现在支持SpatiaLite 不再支持GDAL1.9和1.10

    4. django.contrib.staticfiles

    为collectstatic --ignore选项添加路由,以支持类似/vendor/*.js的模式

    5. Database backends

    为SQLite上的QuerySet.iterator()添加输出流

    6. Generic Views

    新的View.setup钩子将在调用dispatch()方法之前初始化视图属性。

    相关推荐:《Python视频教程》

    7. Internationalization

    现在支持亚美尼亚语言

    8. Management Commands

    新的选项--force-color强制对输出添加颜色inspectdb命令将为PostgreSQL数据库的外部表创建模型inspectdb --include-views将为Oracle和PostgreSQL的物化视图创建模型inspectdb --include-partitions将为PostgreSQL的分区表创建模型。在Oracle和PostgreSQL上inspectdb命令将内省DurationField字段类型,在SQLite上内省AutoField字段类型。在Oracle中,dbshell将被rlwrap包装起来。rlwrap提供一个命令历史记录和键盘输入编辑功能。新的makemigrations --no-header选项可以在生成migration文件的时候避免写入头部注释。runserver命令现在可以使用Watchman插件,用于提高监视大量修改文件的性能。并且不再支持pyinotify插件。

    9. Migrations

    新的migrate --plan选项将打印出迁移操作的列表NoneType现在可以在migrations中序列化了现在可以为migrations注册自定义的序列化器了

    10. Models

    为PostgreSQL ,新增Index.opclasses类通过Index.condition,支持分区索引新增NullIf和Reverse数据库函数为QuerySet.bulk_create()函数新增ignore_conflicts参数,此参数如果设置为True,将忽略在添加数据行时的错误。新增ExtractIsoYear函数新增QuerySet.bulk_update()方法,提高批量更新指定字段的效率对于Model.save()、QuerySet.update()和Model.delete()等单独的操作,Django将不再启动一个事务,这有助于提高自动提交数据库操作的性能SQLite现在支持StdDev和Variance函数Aggregate类现在开始支持DISTINCT聚合操作RelatedManager.add()、create()、remove()、set()、get_or_create()、update_or_create() 等方法现在支持多对多关系。SQLite现在要求最低版本是3.8.3mysqlclient现在要求最低版本是1.3.13

    11. Requests and Responses

    新增HttpRequest.headers,可以快速地访问请求的头部信息

    12. URLs

    新增的ResolverMatch.route属性保存了匹配的URL模式的路由

    13. Validators

    MaxValueValidator、MinValueValidator、MinLengthValidator和MaxLengthValidator 现在可以接收一个可调用的limit_value参数值。

    2.2版本中向后不兼容的地方

    Admin actions的继承方式发生变化

    原来是:

    from django.contrib import admin
    class BaseAdmin(admin.ModelAdmin):
        actions = ['a']class SubAdmin(BaseAdmin):
        actions = ['b']

    在过去,SubAdmin将同时具有'a'和'b'动作,这其实不符合Python继承语法的,因为actions属性被重写了。

    现在,Django2.2将上面的做法改变成更符合Python继承机制,所以要达到上面目的的话,我们需要修改成下面的做法:

    class SubAdmin(BaseAdmin):
        actions = BaseAdmin.actions + ['b']

    cached_property语法发生改变

    在过去,我们都是这么使用alias的:

    from django.utils.functional import cached_propertyclass A:
        @cached_property
        def base(self):
            return ...
        alias = base

    在Python3.6之后,这可能会导致TypeError,所以现在修改成下面的做法:

    from django.utils.functional import cached_propertyimport operatorclass A:
        @cached_property
        def base(self):
            return ...
        alias = property(operator.attrgetter('base'))

    总结:2.2其实没啥新东西!

    最后附上Django的版本路线图和生命周期图:

    Django2.2版本的新特性都有哪些Django2.2版本的新特性都有哪些Django2.2版本的新特性都有哪些

    Django的版本号提高得太快我已经无力吐槽了。2.2之后就是3.0,这是几个意思?


    起源地下载网 » Django2.2版本的新特性都有哪些

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元