Django 学习次日——URL路由及模板渲染方式

URL 的概念及格式:html

  URL的引入:客户端:知道了url 就能够去进行访问;django

  服务端:设置好了url,别人才能访问到我app

  URL :网址(全球统一资源定位符);由 协议,域名(ip port) ,路径,参数,锚点等组成函数

 

 

django路由系统:post

  当一个请求到来时:ui

    一、首先到项目目录下的urls.py(URLconf 根路径配置模块),查找路由规则;编码

 

    二、根URLconf模块,里面定义了 urlpatterns 变量url

    三、urlpatterns 是一个(django.urls.path, django.urls.re_path 对象)列表spa

    四、按顺序运行每一个 url 模式,在第一个匹配的模式中止3d

    五、一旦匹配,django 导入并调用给定的视图(views.py 文件)

 

    六、若是中间出错,或者没有匹配到,返回404

  django 搜索 url 只搜索路径部分,跟参数,与请求方法(get ,post)无关;

 

path 和 re_path:

  path基本规则:

 

 

    path(route, view, kwargs=None, name=None)

      route 是一个字符串的 url 规则

      view 是个视图

      kwargs 额外参数,传递给 view ,必须是一个字典

      name url的命名

 

在 url 中捕获参数:

  在 url 规则中使用 <变量名> 能够捕获 url 中的值传递给视图 (捕获的值是字符串)

 

路径转换:

转换器的使用:

一、设置 url:

from django.urls import path 

urlpatterns = [
          path('test/<int:xx>',views.test),
        ]

 

二、在视图中将获取到的参数和参数的类型打印出来:

from django.http import HttpResponse 

def test3(request,xx):
  print(xx,type(xx))
  return HttpResponse('hello %s'%xx)

  注:同一个试图的变量名 (xx)要一致

 

经常使用的转换器:

  str 匹配除了路径分隔符 / 以外的非空字符串,这是默认的形式

  int 匹配正整数,包含0

  slug 匹配字母,数字及横杠,下划线组成的字符串;任意ASCII码

  uuid 匹配格式化的 uuid ,如 075194d3-6885-417e-a8a8-6c931e272f00

  path 匹配任何非空字符串,包含了路径分隔符

re_path 正则匹配:

  格式:

from django.urls import re_path 

urlpatterns = [ re_path(r'test/(?P<变量名>正则),views.test), ]

 

包含其余的 URLconfs :用 include

  一个project有一个总的urls.py各个app也能够本身创建本身的urls.py用include()函数在project的urls.py文件进行注册

  在根目录的 url 配置文件(urls.py)中添加

 

 

传递额外参数:

path,re_path 方法中,传递一个kwargs 的字典参数给视图函数;视图函数能够经过 key 获取到

# 写在主 URL 配置文件会给其路径下的每个路由都加上该参数: 
from django.urls import path,include

urlpatterns = [
  path('test/',include('test1.urls'),kwargs={'key':'value'})
  path('test/',views.test,kwargs={'key':'value'})
  ]

 

 

name的做用:

  给一个匹配的 url 地址取名字;通常用于模板,也可使用 reverse 进行页面重定向

 

 

 

跳转路由:

# views.py 文件里: 

from django.shortcuts import redirect,reverse def article(request,**kwargs) return redirect(reverse('new_artivle')) # 这里能够直接使用 刚刚自定义好的 name 值 return redirect('http://www.baidu.com') # 直接填入要跳转的 url return 
   redirect('/test/test1/') # 直接填入自定义的路由

  redirect 是重定向,reverse是将 url 的 name 解析成 url 自己的函数

 

  app_name :

    定义在 app 文件夹下的 urlconf 模块中

    app_name = app 名称

# 当前app 中 urls.py 文件里 
 app_name = 'test' urlpatterns = [ path('test/',views.test,name="xx"), ]

 

 

# 当前 app 中 views.py 文件里 
from django.shortcuts import redirect,reverse def test(request): return redirect(reverse('test:xx'))

  这样能够避免两个不一样的 app 定义了同样的 name

  name 参数能够给这个 url 取一个合适的名字,经过给 url 取名字,之后再 view 或者模板中使用这个 url,就只须要使用这个名字就能够了,这样作的缘由是防止 url 的规则更改,会致使其余地方用了这个 url 的地方都须要更改,可是若是取名字了,就不要作任何改动了

 

模板路径配置:

  模板放在哪?

    一、再主目录下建立一个 templates 目录用来存放全部的 html 的模板文件;

    二、templates 目录里面再建立各个以 app 名字命名的目录来存放各个app中的模板文件

 

setting.py 中的模板路径配置:

将设置好的存放 html 模板的 templates 目录路径添加到 DIRS 中

'DIRS':[os.path.join(BASE_DIR,'templates')],

 

 

模板渲染方式:

  一、直接将 html 字符串硬编码 HttpResponse 中

from django.http import HttpResponse def test(request): return HttpResponse('<h1 style="color:red">hello world</h1>')

 

  二、django.template.loader 定义了函数以加载模板

from django.template.loader import get_template from django.shortcuts import render from django.http import HttpResponse def test(request): t = get_template('test/test.html') # 这里直接写 templates 里的路径 
    html = t.render() return HttpResponse(html)

 

  三、使用 render 进行渲染:

from django.shortcuts import render def test(request): return render(request,'test/test.html') # 这里直接写 templates 里的路径

  render 方法是 django 封装好用来渲染模板的方法很方便,很好用!

相关文章
相关标签/搜索