博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django_05_模板
阅读量:5834 次
发布时间:2019-06-18

本文共 1373 字,大约阅读时间需要 4 分钟。

模板

  • 如何向请求者返回一个漂亮的页面呢?肯定需要用到html、css,如果想要更炫的效果还要加入js,问题来了,这么一堆字段串全都写到视图中,作为HttpResponse()的参数吗?这样定义就太麻烦了吧,因为定义字符串是不会出任何效果和错误的,如果有一个专门定义前端页面的地方就好了
  • 解决问题的技术来了:模板
  • 在Django中,将前端的内容定义在模板中,然后再把模板交给视图调用,各种漂亮、炫酷的效果就出现了

创建模板

  • 为应用booktest下的视图index创建模板index.html,目录结构如下图:

  • 设置查找模板的路径:打开test1/settings.py文件,设置TEMPLATES的DIRS值
'DIRS': [os.path.join(BASE_DIR, 'templates')],

  

定义模板

  • 打开templtes/booktest/index.html文件,定义代码如下
  • 在模板中输出变量语法如下,变量可能是从视图中传递过来的,也可能是在模板中定义的
{
{变量名}}
  • 在模板中编写代码段语法如下
  
{%代码段%}
  • 定义模板内容如下:模板语言
    图书列表  

{
{title}}

  {
%for i in list%}  {
{i}}
  {
%endfor%}

视图调用模板

  • 调用模板分为三步骤
    • 1.找到模板
    • 2.定义上下文
    • 3.渲染模板
  • 打开booktst/views.py文件,调用上面定义的模板文件
#coding:utf-8from django.http import HttpResponsefrom django.template import loader,RequestContextdef index(request):    # 1.获取模板    template=loader.get_template('booktest/index.html')    # 2.定义上下文    context=RequestContext(request,{
'title':'图书列表','list':range(10)}) # 3.渲染模板 return HttpResponse(template.render(context))
  • 打开浏览器刷新页面,显示效果如下图

视图调用模板简写

  • 视图调用模板都要执行以上三部分,于是Django提供了一个函数render封装了以上代码
  • 方法render包含3个参数
    • 第一个参数为request对象
    • 第二个参数为模板文件路径
    • 第三个参数为字典,表示向模板中传递的上下文数据
  • 打开booktst/views.py文件,调用render的代码如下
#coding:utf-8from django.shortcuts import renderdef index(request):    context={
'title':'图书列表','list':range(10)} return render(request,'booktest/index.html',context)

 

转载于:https://www.cnblogs.com/yaboya/p/8926339.html

你可能感兴趣的文章
让你的WPF程序在Win7下呈现Win8风格主题
查看>>
802.11 学习笔记
查看>>
Leetcode-Database-176-Second Highest Salary-Easy(转)
查看>>
构建Docker Compose服务堆栈
查看>>
最小角回归 LARS算法包的用法以及模型参数的选择(R语言 )
查看>>
Hadoop生态圈-Kafka常用命令总结
查看>>
如何基于Redis Replication设计并实现Redis-replicator?
查看>>
浮点数内存如何存储的
查看>>
贪吃蛇
查看>>
EventSystem
查看>>
用WINSOCK API实现同步非阻塞方式的网络通讯
查看>>
玩一玩博客,嘿嘿
查看>>
Ubuntu设置python3为默认版本
查看>>
JsonCpp 的使用
查看>>
问题账户需求分析
查看>>
JavaSE-代码块
查看>>
爬取所有校园新闻
查看>>
32、SpringBoot-整合Dubbo
查看>>
python面向对象基础
查看>>
HDU 2044 一只小蜜蜂(递归)
查看>>