mustache模板渲染的基本原理
mustache.js是一个模板引擎,为开发节省了大量的“人力”,对于初学者,我是从这篇 和这篇 博客接触的,算是对mustache有了初步认识,不得不承认自己还是菜鸟阶段还有太多东西要学,慢慢熟悉。
在初步了解mustache后,我仿照公司使用的技巧写了一个demo:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script type="text/javascript" src="C:\Users\Administrator\Desktop\mustache.js"> </script> <script id="emacleTempl" class="mustache-template" type="text/template">
<h1>标题:[[title]]</h1>
<p>下面是我的个人信息:</p>
<h2>姓名:[[name]]</h2>
<h2>年龄:[[age]]</h2>
<h2>身高:[[height]]</h2>
<h2>学校:[[school]]</h2>
<h3>工作:[[#job]] [[.]] [[/job]]</h3>
<h3>地址:[[#addres]]<p>城市:[[city]]<p>科室:[[zip]]<p>[[/addres]]</h3>
[[#edu]]
教育信息:我的学校是:[[school]] !!
[[/edu]]
</script>
</head>
<body>
<div id="d2"></div>
</body> <script type="text/javascript">
var tem=document.getElementById("emacleTempl").innerHTML;
var d2=document.getElementById("d2"); var data={
title:"个人资料",
name:"jim",
age:20,
height:180,
school:"辽宁工程技术大学大学",
addres:{
city:"北京",
atate:"朝阳",
zip:512
},
job:["java","js","css","html","ps"],
edu:true //true时加载,flase时不加载 }; var html = Mustache.render(tem,data); //渲染数据
d2.innerHTML=html; //把渲染结果插入空div中,显示 </script>
</html>
在demo里有几个关键点这里需要声明一下,第一就是代码中的第二个<script>标签,重点是它的type="text/template" 而不是“text/javascript”,没错就是让他不能正常识别为js代码,因为它内部本身就不是js,识别了反而会报错。它存放的是渲染模板,本打算单独成一个html文件的,但不利于查看,就写在一起了,我司的模板都是一个个html文件,文件里就一个<script type="text/template">标签。也就是说,网页是从模板中选择性加载的,怎样选择呢?那就是底部的js代码控制的,先看模板吧:
<script id="emacleTempl" class="mustache-template" type="text/template">
<h1>标题:[[title]]</h1>
<p>下面是我的个人信息:</p>
<h2>姓名:[[name]]</h2>
<h2>年龄:[[age]]</h2>
<h2>身高:[[height]]</h2>
<h2>学校:[[school]]</h2>
<h3>工作:[[#job]] [[.]] [[/job]]</h3>
<h3>地址:[[#addres]]<p>城市:[[city]]<p>科室:[[zip]]<p>[[/addres]]</h3>
[[#edu]]
教育信息:我的学校是:[[school]] !!
[[/edu]]
</script>
最后一个[[#edu]]为true时加载,flase时不加载,这就是所谓的选择性加载,下面看看控制加载的js代码吧:
<script type="text/javascript">
var tem=document.getElementById("emacleTempl").innerHTML;
var d2=document.getElementById("d2"); var data={
title:"个人资料",
name:"jim",
age:20,
height:180,
school:"辽宁工程技术大学大学",
addres:{
city:"北京",
atate:"朝阳",
zip:512
},
job:["java","js","css","html","ps"],
edu:true //true时加载,flase时不加载
}; var html = Mustache.render(tem,data); //渲染数据
d2.innerHTML=html; //把渲染结果插入空div中,显示 </script>
js代码定义了data,里面存着渲染信息,最后通过Mustache.render(tem,data)渲染,并把渲染的结果作为innerHTML插入到指定标签中,这样就实现了选择性加载,如果要更改数据只需更改data就行,基本原理就是这样,当然实际情况要比这复杂。一个模板成千上万行代码也是很常见的。同志仍需努力!
mustache模板渲染的基本原理的更多相关文章
- mustache模板技术
一.简介Web 模板引擎是为了使用户界面与业务数据(内容)分离而产生的,它可以生成特定格式的文档,通常是标准的 HTML 文档.当然不同的开发语言有不同模板引擎,如 Javascript 下的 Hog ...
- JS模板引擎-Mustache模板引擎使用实例1-表格树
1 使用实例代码 1.jsp代码 <!DOCTYPE html> <html lang="zh-CN"> <head> <title> ...
- 【nodejs笔记3】Express基本用法,和路由控制,和模板渲染ejs
1. 路由控制的工作原理 //routes/index.js中的代码//访问主页时,调用ejs模板引擎,渲染index.ejs模板文件,生成静态页面,并显示在浏览器中.router.get('/', ...
- python Django教程 之模板渲染、循环、条件判断、常用的标签、过滤器
python3.5 manage.py runserver python Django教程 之模板渲染.循环.条件判断.常用的标签.过滤器 一.Django模板渲染模板 1. 创建一个 zqxt_tm ...
- Flask -- 静态文件 和 模板渲染
静态文件 一般用于存放图片,样式文件(css, js等) 保存位置:包中或者文件所在目录创建一个 static 目录 访问:在应用中使用 /static/...即可访问 , 更好的方式是使用url_f ...
- 出位的template.js 基于jquery的模板渲染插件
找了好几款基于jquery的模板渲染插件,无一感觉很难用(教程较少.绑定不统一),也可能我智商问题,比如jquery template.js .jtemplate.js. 然后在github上找到这一 ...
- Django中的模板渲染是什么
首先建立一个页面 在views.py中增加一个方法 配置URL 如何实现的呢 这就是渲染,传递的数据不同显示的数据也不同.Django里的渲染引擎和Jinja的虽然不同但是语法基本通用.现在明白什么叫 ...
- Swagger结合mustache模板生成后台接口代码、以及前后台建模代码
之前项目中使用的的thrift来建模,维护前后台模型以及rest接口,前台使用的是angular2: 但是使用thrift只能生成建模,后台的rest接口的Controller文件还是需要手动去写,一 ...
- thinkphp3.2.3模板渲染支持三元表达式
thinkphp3.2.3模板渲染支持三元表达式 {$status?'正常':'错误'} {$info['status']?$info['msg']:$info['error']} 注意:三元运算符中 ...
随机推荐
- mac word 快捷键
https://support.office.com/en-us/article/Word-keyboard-shortcuts-c0ca851f-3d58-4ce0-9867-799df7366 ...
- Java分布式应用技术架构介绍
分布式架构的演进 系统架构演化历程-初始阶段架构
- Material Design UI Widgets
Android L 开发者预览支持库提供两个新的Widgets,RecyclerView和CardView.使用这两个Widgets可以显示复杂的Listview和卡片布局,这两个Widgets默认使 ...
- mysql 行转列
SELECTREPLACE(GROUP_CONCAT(IF(ItemID=1101,ItemValue,"")),',',"") AS 'Item1101',R ...
- LDPC编译码基本原理
LDPC编译码基本原理 学习笔记 V1.1 2015/02/18 LDPC编译码基本原理 概述 本文是个人针对LDPC的学习笔记,主要针对LDPC译码算法做了简要的总结.该版本主要致力 ...
- 爬虫技术 -- 基础学习(一)HTML规范化(附特殊字符编码表)
最近在做网页信息提取这方面的,由于没接触过这系列的知识点,所以逛博客,看文档~~看着finallyly大神的博文和文档,边看边学习边总结~~ 对网站页面进行信息提取,需要进行页面解析,解析的方法有以下 ...
- ruby -- 基础学习(一)项目文件夹说明
App文件夹子文件夾功能介绍 (1)controllers 存放驱动业务逻辑的控制器 (2)helpers 存放视图辅助类,一些常用的代码段 (3)mailers Rails ...
- 说说你所熟知的MSSQL中的substring函数
说说你所熟知的MSSQL中的substring函数 *:first-child { margin-top: 0 !important; } body>*:last-child { margin- ...
- SharePoint 2013中规划企业搜索体系结构
摘要:了解如何规划小型.中型或大型企业搜索体系结构. 设置企业搜索体系结构之前,需要仔细规划很多事项.我们将逐步帮助您规划小型.中型或大型企业搜索体系结构. 您是否熟悉 SharePoint 2013 ...
- Hadoop入门进阶课程3--Hadoop2.X64位环境搭建
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,博主为石山园,博客地址为 http://www.cnblogs.com/shishanyuan ...