Python3.5 学习二十四

2022-11-13,,

本节课程大纲:

-----------------------------------------------------------------------------------------------------------

  Model:

    -数据库操作

    -验证

  Form:

    class LoginForm():

      email = fields.EmailField()

    -is_valid ->每一个字段进行正则(字段内置正则)  +  clean_字段  -> clean(__all__) ->  _post_clean

    -cleand_data

    -error

推荐使用,耦合低

-----------------------------------------------------------------------------------------------------------

一、ModelForm

  Model+Form结合体  --> 验证+数据库操作

  

  结合20181010的实例,看使用ModelForm带来的便利性

  obj.save()可将单表、多对多关联表数据一并保存

  但只会保存单表数据,而不保存多对多表记录,可以看源码分析其原理。

    想要加入M2M表记录,需要多执行以下一句代码:

    obj.save_m2m()

  

  Userinfo列表编辑保存,用ModelForm的实现源码中,注意点:

  1、修改界面的数据保存,需要引用instance

Django2.0后,URL中需要引入re_path来生成一个带有正则的url对应

页面上也可以自定义一些额外的字段,不需要保存到数据库的

验证的clean钩子用法,和form之前讲的完全一样。

对于ModelForm回顾:

1、可以生成HTML标签,标签可以默认排列,可以逐个写入

  class Meta:。。。定制

2、mf=xxxModelForm(instance=Modelobj) 写入默认值

3、可以自定义加字段,不带入数据库,做验证用等

4、各种验证 is_valid() ->每个字段正则、每个字段方法、clean、Postclean

5、mf.save()   =>instace = mf.save(False)

        instace.save()

        mf.save_m2m()

耦合度高,使用方便,但局限性高,小程序可以用,可能会大的程序就不要用了。

二、Ajax

Ajax全套  http://www.cnblogs.com/wupeiqi/articles/5703697.html

Python开发目录  http://www.cnblogs.com/wupeiqi/articles/5433893.html

  原生  

  1、利用原生XmlHTTPResponse来发送POST请求时,都要设置请求头,一定要注意

  2、原生操作对象的兼容性设置

function getXHR(){
var xhr = null;
if(XMLHttpRequest){
xhr=new XMLHttpRequest();
}
else{
xhr = new ActiveXObject("Microsoft.XMLHTTP");
}
return xhr;
}

  jQuery

  伪Ajax操作:

  

伪Ajax提交的数据获取:

  三种选择的时机:

    如果是普通数据(非文件),推荐使用顺序:jQuery,XMLHttpRequest,iframe

    

三、文件上传(图片预览)

  -Form提交

  -Ajax上传

{#          jquery上传文件时,需要设置以下两个参数#}
processData:false,
contentType:false,

  

  -iframe上传

三种方式实现代码见程序20181010

文件上传选择时机:iframe,jQuery(FormData),XMLHttpRequest(FormData)

图片上传后的预览:上传后找到文件路径,然后加一个‘/’,作为可读取位置

用Jquery动态生成载入一个img标签显示即可。

如果不想单独点按钮上传,可以在文件input框的onchange事件中写上传方法。

四、图片验证码  +  Session

实现流程:

Get请求:生成验证码、存放入Session

    创建一张图片给用户返回

POST请求:提交数据,提交验证码,服务器将提交的数据和Session进行对比验证

静态文件不需要写URL,因为Django是后台在帮助打开读取返回的操作。

总结:

--session

-check_code.py(依赖:Pillow;字体文件)

-刷新验证码:利用src属性后面加“?”

    

五、富文本插件  CKEditor,UEEditor,TinyEditor,KinkEditor

  -基本使用

  参考笔记:http://www.cnblogs.com/wupeiqi/articles/6307554.html

  -文件上传、多文件上传、文件空间管理

  学习Kindle中各种文件上传

  --XSS攻击(过滤的函数)

关于跨表操作的性能提升方式:

1 Queryset.selectedrelated  直接跨表到关联表,读所有记录  

2 Queryset.prefishrelated  两次跨表,第一次找__ID字段值,第二次跨表查 in __ID字段值的记录,放入内存,以提高效率

作业:

主站:

  http://127.0.0.1:8000  博客首页

  http://127.0.0.1:8000/xxx/1.html  某人的某篇文章

个人博客:

  http://127.0.0.1/xxx/  某人的博客

  http://127.0.0.1/xxx/tag/python.html 某人的博客分类 

  http://127.0.0.1/xxx/catetory/mvc.html 某人的博客分类

  http://127.0.0.1/xxx/date/2011-11.html 某人的博客分类  

个人后台管理:

  个人信息管理

  标签管理

  分类管理

  文章管理

    创建

    修改文章

    

Python3.5 学习二十四的相关教程结束。

《Python3.5 学习二十四.doc》

下载本文的Word格式文档,以方便收藏与打印。