路由层

  

 url路由层结构

from django.conf.urls import url
from django.contrib import admin
from app01 import views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^$', views.index),
url(r'^index/', views.index, name='index'),
] url(正则表达式, views视图函数,参数,别名)

  在Django1.0版本中路由层,第一个参数就是一个正则表达式,也就意味着路由在匹配的时候是按照正则表达式的规则取匹配的, 路由的匹配顺序是从上到下依次匹配,匹配到之后马上执行视图

函数,不在向下继续匹配路由。

  按照正则表达式语法,就可以实现首页的路由书写方式,和不存在页面(错误页面404)路由的书写方式

,注意错误页面位置放到最后。

  匹配一个到无限个数字的路由书写方式:

  常用的解决错误匹配的方法:1 切换位置 2 换正则表达式。

  Django2.0版本中url 变为了path,但是它也保留了正则的方式:

补充说明:

# 是否开启URL访问地址后面不为/跳转至带有/的路径的配置项
APPEND_SLASH=True Django settings.py配置文件中默认没有 APPEND_SLASH 这个参数,但 Django 默认这个参数为 APPEND_SLASH = True。 其作用就是自动在网址结尾加'/'。 其效果就是: 我们定义了urls.py:
from django.conf.urls import url
from app01 import views urlpatterns = [
url(r'^blog/$', views.blog),
] 访问 http://www.example.com/blog 时,默认将网址自动转换为 http://www.example/com/blog/ 。 如果在settings.py中设置了 APPEND_SLASH=False,此时我们再请求 http://www.example.com/blog 时就会提示找不到页面。

Django 1.0 与2.0 的差别

django2.0里面的path第一个参数不支持正则,你写什么就匹配,100%精准匹配

django2.0里面的re_path对应着django1.0里面的url

虽然django2.0里面的path不支持正则表达式,但是它提供五个默认的转换器

str,匹配除了路径分隔符(/)之外的非空字符串,这是默认的形式
int,匹配正整数,包含0。
slug,匹配字母、数字以及横杠、下划线组成的字符串。
uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。
path,匹配任何非空字符串,包含了路径分隔符(/)(不能用?) 自定义转换器
1.正则表达式
2.类
3.注册 # 自定义转换器
class FourDigitYearConverter:
  regex = '[0-9]{4}'
def to_python(self, value):
return int(value)
def to_url(self, value):
return '%04d' % value # 占四位,不够用0填满,超了则就按超了的位数来!
register_converter(FourDigitYearConverter, 'yyyy')
PS:路由匹配到的数据默认都是字符串形式

有名分组与无名分组

  分组的目的:利用正则分组手段,来实现参数的传递。例如在编辑用户的时候,我们需要获取用户的id,之前是借助 href get请求传值的方式,将用户的id传到后台。现在我们有了更专业的手段。

  分组分类:

    有名分组,我将其理解为位置参数的传值方式,使用方式如下图,浏览器用户输入的网址中,test/ 后方的2018,在url.py 中利用正则分组的方式,将其作为位置参数,传给view层的test函数的xxx。

  这样就完成了前端对后端的参数传递,和之前利用a标签在get模式下的传参方式如出一辙。获取到这个参数之后,就可以进行新的一通骚操作了。

 

    无名分组,我将其理解为关键字参数的传值方式,和无名分组大差不差,就是参数前面指定了一个名称,这个名称有指定的作用,和函数的位置与关键字传参如出一辙。使用方式如下图:

  ?P<year> 就是固定的书写格式,year就是参数名称,所以对应于view层中的函数也必须有year这个形参来接收。

    注意:有名分组于无名分组不要混着用,这是规定,没有为什么!当然相同类型也可以传多个参数。

  

反向解析

  随着功能的增加会出现更多的视图,可能之前配置的正则表达式不够准确,于是就要修改正则表达式,但是正则表达式一旦修改了,之前所有对应的超链接都要修改,真是一件麻烦的事情,而且可能还会漏掉一些超链接忘记修改,有办法让链接根据正则表达式动态生成吗? 就是用反向解析的办法。

  应用范围:

    1 模板中的超链接

    2 视图中的重定向

  正如上面所说,如果我们时不时的更改正则表达式,此时我们就要改很多的地方,那有没有一种方式能够不那么麻烦,也能随意的改正则表达式呢,答案就是给这个url 命名。

如图所示,在函数名后面加一个 name= ’名称‘ 的方式,为该url贴个名字,有了这

个名字之后,前端后端下次再只需要通过这个名字取匹配相应的url ,此时无论你怎样去改动url中的正则表达式都无所谓,因为它们以及换成了 名字 来链接彼此了。此时要注意,这个

名字是一定不能重复的。 既然说是用名字来替代前面的url,那具体如何使用呢:

  前端使用方式:

  标准的模板语法。

  后端使用方式,先解释,后端是想通过这个名字反向得到    名字所代表      url的正则表达式,以达到无论正则表达式怎么变,我只要后端名字和url保持一致,就能拿到这个url中的正则表达式。

通常这里是结合(redirect)重定向来使用,也就是你前面url正则随意变,我重定向永远能匹配到你。这里就使用到了reverse 模块。

  首先是导入 reverse 然后如图操作

  结论:有了反向解析之后,我们就不用再担心,改了url的正则表达式之后,又得改view 和 html中的正则表达式,有了名字之后,就省事多了。但是此时又有了新的问题,上面所说的有名分组和无名分组

的参数要怎么结合着使用呢?

  

 路由分发

  项目中的urls层作为一个大组长,每个app就是一个个体,路由来了先由大组长分发到每个个体中的urls.py中,来做匹配。这样的好处在于,大组长里不需要把所有的路由都写下来,

结构更加清晰,适合一个项目中有多个app的场景。注意分发总路由千万不要写$结尾

  

伪静态码(seo搜索引擎优化)

  作用:提升网页颗粒度,让搜索引擎更容易搜索到,因为搜索引擎会优先记录以html结尾的静态页面。

模拟环境

  为啥要用虚拟环境:一个项目中需要的模块是有限的,虚拟环境可以避免导入一些无用的模块,需要什么模块就导入什么模块。本质上就是下载了一个新的pycham,一个纯净的环境。

换源的方法:百度搜索pip源,复制清华源的url 在项目中添加,双击任意一个现有模块,删除之前的源,添加新源url。

FBV/CBV

  

  FBV  fouction base view,基于函数的视图

  CBV      class base view 基于函数的视图

  

class MyCls(View):
def get(self,request):
return render(request,'index.html')
def post(self,request):
return HttpResponse('post')

使用JSON实现前后端分离

  

  dumps 内部加入ensure——ascii之后 序列化的字符串中中午不会在自动编码。Django自带的方式,

 JsonResponse(将相应的数据自动转换成json格式,然后直接发送回浏览器)

导入模块
from django.http import JsonResponse
import json 原始方法:
def index(request):
res = {'name':'sgt','password':18}
return HttpResponse(json.dumps(res)) JsonResponse方法:
def index(request):
return JsonResponse(
{'name':'sgt','password':''},
json_dumps_params={'ensure_ascii':False}
) 注意:json_dumps_params={'ensure_ascii':False}这个的作用是,将Django默认转码功能取消,这样就能显示汉字了。

文件上传

1 注意form表单数据提交的方式

2 请求通过点 FILES方法可以获取文件字典对象,通过get()方法可以获取字典中的值

3 get(‘my_file’)可以获取FILES请求中的文件数据。

request.path 与 request.get_full_path 区别:get_full_path可以获取用户输入的完整路径。

随机推荐

  1. freeCodeCamp:Return Largest Numbers in Arrays

    右边大数组中包含了4个小数组,分别找到每个小数组中的最大值,然后把它们串联起来,形成一个新数组. 提示:你可以用for循环来迭代数组,并通过arr[i]的方式来访问数组的每个元素. /*思路 for循 ...

  2. 我所常用的ajax调用格式

    ajax: $.ajax({    type: "post",    datatype: "json",    contentType: "appli ...

  3. [UEditor]百度编辑器配置总结

    前端配置文件ueditor.config.js 前端有两个重要的配置属性: UEDITOR_HOME_URL: 配置百度编辑器的资源目录路径,你可以手动指定此路径,默认是有URL变量指定,而URL变量 ...

  4. Kruskal最小生成树

    并查集+kruskal==>MST 效率很低 #include <iostream> using namespace std; #define MAX 105 //自己设置最大值 / ...

  5. 动态Script标签 解决跨域问题

     动态Script 解决跨域问题 1.动态创建scriptcreateScript : function(src){ var varScript = document.createElement(&q ...

  6. MDK C++中对内联的极度优化

    先来看看我们SmartIRQ的具体实现 // 智能IRQ,初始化时备份,销毁时还原 class SmartIRQ { public: force_inline SmartIRQ(bool enable ...

  7. 腾讯云极速配置NodeJS+LNMP运行环境

    版权声明:本文由吴逸翔原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/848754001487150669 来源:腾云阁 h ...

  8. 德国Aptamil不同系列奶粉间差别

    以下内容均来源网络整理.汇总. 德国人做事严谨,而且对于有争议性的成分持保守态度,比如不添加麦芽糊精.所以我比较赞赏购买德国的奶粉,主要是aptamil和hipp喜宝,这两个牌子也基本没有负面新闻.但 ...

  9. div+css 命名规则

    编写网页的时候,一般都没有把命名规则认真对待.在结合语义以及搜索优化两方面给出了一套命名方案,对增强阅读性.规范性和提高开发效率是有帮助的,当然,这方面的规范,仁者见仁智者见智,网上有许多前辈们以经验 ...

  10. 12c ocp 062新考题(之前没出现过)-1

    1.One of your databases has archive logging enabled and RMAN backups are taken at regular intervals. ...