django_2:模板
使用模板变量:
在html文件中,{{title}}即为模板变量,
在view.py文件中,render函数,增加第三个参数,以字典形式给值。
def index(req):
return render(req, 'index1.html', {'title': 'mypage', 'user': 'tom'})
可以将‘mypage’,‘tom’改成变量,实现接口和动态;
该变量可以是基本变量(单值)、字典、list、类等,在html中可以索引{{user.key}}
字典
def index(req):
user = {'name':'tom', 'age':, 'sex':'male'}
return render(req, 'index1.html', {'title': 'mypage', 'user': user})
对象
(可以使用的对象属性、方法),在调用对象的方法时,注意没有参数,要有return
def index(req):
user = Person('tom', , 'male')
return render(req, 'index1.html', {'title': 'mypage', 'user': user})
在html中存在优先级:先基本变量,再字典、对象的属性、对象的方法、最后列表
模板标签的使用:
{% if xx%}
{% else %}
{% endif %}
判断条件xx:
- 可以是变量,判断变量是否存在
- 可以是boolean操作, 使用and、or、not;注意不能使用();django1.3不可以and和or连用,django1.11可以
- 可以是关系运算,等于,不等于,大小,大于等于等,注意:必须要有空格隔开!
- 可以是in、not in运算
{% for book in book_list %}
<li>book</li>
{% empty %} #可以没有这句
book_list为空
{% endfor %}
- 被遍历对象可以是llist
- 对字典遍历,跟python对dict遍历一样,for u in user得到键的遍历,for k, v in user.items: {{k}} {{v}}
- 可以是复合数据类型
| forloop.counter |
序号,从1开始 |
| forloop.counter0 |
从0开始 |
| forloop.revcounter |
反向 |
| forloop.revcounter0 |
反向 |
| forloop.first |
True if the firsh through the loop |
| forloop.last | |
| forloop.parentloop |
for nested loops, this is the loop 'above' the current one |
- for ... empty
使用模板:
#from django.shortcuts import render
#coding:utf-
#from django.shortcuts import render
from django.template import loader, Context, Template
from django.http import HttpResponse # Create your views here.
def index(seq):
t = loader.get_template('index.html') #加载模板,用文件
c = Context({'uname': 'alen'}) #生成Context对象
html = t.render(c) #渲染
return HttpResponse(html) #输出,我的测试报错!没找到问题 def index1(req):
t = Template('<h1>hello {{uname}}</h1>') #用字符串,生成模板对象
c = Context({'uname':'csvt'})
html = t.render(c) #渲染
return HttpResponse(html) #输出,测试成功
以上两种方法,被简化为使用render方法
1.3使用的是from django.shortcuts import render_to_response
django_2:模板的更多相关文章
- Jade模板引擎让你飞
写在前面:现在jade改名成pug了 一.安装 npm install jade 二.基本使用 1.简单使用 p hello jade! 渲染后: <p>hello jade!</p ...
- ABP入门系列(2)——通过模板创建MAP版本项目
一.从官网创建模板项目 进入官网下载模板项目 依次按下图选择: 输入验证码开始下载 下载提示: 二.启动项目 使用VS2015打开项目,还原Nuget包: 设置以Web结尾的项目,设置为启动项目: 打 ...
- CMS模板应用调研问卷
截止目前,已经有数十家网站与我们合作,进行了MIP化改造,在搜索结果页也能看到"闪电标"的出现.除了改造方面的问题,MIP项目组被问到最多的就是:我用了wordpress,我用了织 ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- 【原创分享·微信支付】C# MVC 微信支付之微信模板消息推送
微信支付之微信模板消息推送 今天我要跟大家分享的是“模板消息”的推送,这玩意呢,你说用途嘛,那还是真真的牛逼呐.原因在哪?就是因为它是依赖微信生存的呀,所以他能不 ...
- OpenCV模板匹配算法详解
1 理论介绍 模板匹配是在一幅图像中寻找一个特定目标的方法之一,这种方法的原理非常简单,遍历图像中的每一个可能的位置,比较各处与模板是否“相似”,当相似度足够高时,就认为找到了我们的目标.OpenCV ...
- 前端MVC学习总结(一)——MVC概要与angular概要、模板与数据绑定
一.前端MVC概要 1.1.库与框架的区别 框架是一个软件的半成品,在全局范围内给了大的约束.库是工具,在单点上给我们提供功能.框架是依赖库的.AngularJS是框架而jQuery则是库. 1.2. ...
- ThinkPHP+Smarty模板中截取包含中英文混合的字符串乱码的解决方案
好几天没写博客了,其实有好多需要总结的,因为最近一直在忙着做项目,但是困惑了几天的Smarty模板中截取包含中英文混合的字符串乱码的问题,终于解决了,所以记录下来,需要的朋友看一下: 出现乱码的原因: ...
- ThinkPHP 模板substr的截取字符串函数
ThinkPHP 模板substr的截取字符串函数在Common/function.php加上以下代码 /** ** 截取中文字符串 **/ function msubstr($str, $start ...
随机推荐
- 数据结构2_java---栈,括号匹配
package Main; import java.util.Scanner; import javax.swing.text.html.HTMLDocument.HTMLReader.Isindex ...
- LeetCode初级算法--动态规划01:爬楼梯
LeetCode初级算法--动态规划01:爬楼梯 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net ...
- Vue中axios的封装和api接口的统一管理
更新的是我csdn上的文章,需要的话可以看下,互相学习点击去我的csdn vue中axios的封装 在vue项目和后端交互获取数据时,通常使用axios库,官方文档:https://www.npmjs ...
- 06 python学习笔记-常用模块(六)
一. 模块.包 1.什么是模块? Python 模块(Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和Python语句,是用来组织代码的.模块能定义函数 ...
- 为什么要用dubbo,dubbo是什么,为什么要和zk结合使用?
目录 为什么要用dubbo dubbo是什么 dubbo架构 dubbo和zk关系 为什么要用dubbo? 随着互联网的发展,网站的应用规模不断扩大,常规的垂直架构已经无法应,分布式服务架构势在必行, ...
- 该虚拟机似乎正在使用中。 如果该虚拟机未在使用,请按“获取所有权(T)”按钮获取它的所有权。否则,请按“取消(C)”按钮以防损坏。 配置文件: ***.vmx。
打开虚拟机的时候,出现这样的问题: 该虚拟机似乎正在使用中. 如果该虚拟机未在使用,请按“获取所有权(T)”按钮获取它的所有权.否则,请按“取消(C)”按钮以防损坏. 配置文件: D:\VM\wi ...
- PHPStorm 10 配置PHPUnit
PHPStorm 10 配置PHPUnit PHPUnit的安装 自己用的是Xampp,PHPUnit好像自带不好用. 不说废话: 自己看 According to official site htt ...
- Md5与HMAC-SHA256
Md5签名算法 private string CalMd5(string str) { var md5 = MD5.Create(); var bs = md5.ComputeHash(Encodin ...
- 使用 HTML5 WebSocket 构建实时 Web 应用
原文地址:http://www.ibm.com/developerworks/cn/web/1112_huangxa_websocket/ HTML5 WebSocket 简介和实战演练 本文主要介绍 ...
- C++学习笔记1_ 指针.引用
1.引用的本质struct typeA{ int &a;}struct typeB{ int *a;}int main(void){ cout<<sizeof(struct typ ...