js模板引擎mustache介绍及实例

2024-05-09 09:32

本文主要是介绍js模板引擎mustache介绍及实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

亲测可用,若有疑问请私信

在Javascript中 mustache.js是实现mustache模板系统。

Mustache是一种没有逻辑的模板语法。它可以应用于HTML、配置文件、源代码等任何地方。 它通过使用散列或对象中提供的值在模板中展开标记来工作。

我们称它为没有逻辑的模板,是因为它没有if语句、else子句和for循环,它只有标签。一些标签被替换为值或什么也没有或者一系列的值

不能在模板中使用else if做逻辑判断,我们可以在数据传入之前对数据做逻辑操作

我们在那使用mustache.js

你可以在任何可以使用JavaScript的地方使用mustache.js来渲染mustache模板。包括web浏览器、服务器环境(node)。

语法

  • 模板以{{}}包裹住内容,格式中写入的是模板的内容。 被替换的内容字段使用双花括号包裹起来。
  • 插值表达式:双花括号{{}} 包裹替换的字段
  • {{#prop-name}}{{/prop-name}}用作for循环渲染,当prop-name的值为非空数组时,mustach不会遍历该数组,渲染出个数和该数组长度相等的DOM元素
  • 也可以用作if-else判断。{{#prop-name}}{{/prop-name}}和{{^prop-name}}{{/prop-name}}两组标签结合使用,当prop-name的值存在且不为false时,会渲染{{#prop-name}}{{/prop-name}}的内容,否则渲染{{^prop-name}}{{/prop-name}}的内容
 
  1. <script id="template" type="x-tmpl-mustache">

  2. {{name}}

  3. </script>

  4. <script type="text/javascript">

  5. var template = $("#template").html();

  6. //name值为函数返回值

  7. var r = Mustache.render(template,{

  8. name:function(){

  9. return 'abc' //abc会替换双花括号内name

  10. }

  11. })

  12. //name值为字符串

  13. var r = Mustache.render(template,{name:'wan'}) //字符串wan会替换双花括号内的name

  14. </script>

我们注意到上面代码render的第二个参数都是一个对象(变量和函数都是对象),第二个参数我们通常都会使用对象类型,传入一个对象,在模板中书写对象属性,可以渲染出对象的值。 但也可以是其它类型如 数组、字符串类型、数字,如下:

 
  1. <script id="template" type="x-tmpl-mustache">

  2. {{.}}

  3. </script>

  4. <script type="text/javascript">

  5. function loadUser(){

  6. var template = $("#template").html();

  7. var r = Mustache.render(template,'wan') //渲染出wan

  8. //或

  9. var r = Mustache.render(template,[1,d,3]) //渲染出1,d,3

  10. //或

  11. var r = Mustache.render(template,1) //渲染出1

  12. }

  13. </script>

我们可以看到如果第二个参数是其它类型,那么在模板中双花括号内就用点.来表示,使用起来不方便。 一般在项目中很少会传入其它类型。

对象属性值为数组时 实现forEach遍历数组渲染DOM

 
  1. //页面部分

  2. <div id="target">Loading</div>

  3. //模板

  4. <script id="template" type="x-tmpl-mustache">

  5. <ul>

  6. {{#list}}

  7. <li>

  8. <span>{{name}}</span>

  9. <span>{{age}}</span>

  10. <span>{{job}}</span>

  11. </li>

  12. {{/list}}

  13. </ul>

  14. </script>

  15. //js部分

  16. <script type="text/javascript">

  17. var template = $("#template").html();

  18. var r = Mustache.render(template,{

  19. list:[

  20. {name:'wannianqing',age:18,job:'The Front End'},

  21. {name:'wangxiaosan',age:19,job:'java'},

  22. {name:'lixiaosi',age:20,job:'The Front End'},

  23. {name:'sunxiaowu',age:21,job:'java'}

  24. ]

  25. })

  26. $("#target").html(r)

  27. </script>

用作if-else,属性无论是显示还是隐式转换为boolean类型,true时渲染{{#prop-name}} false时渲染{{^prop-name}}

 
  1. //页面部分

  2. <div id="target">Loading</div>

  3. //模板

  4. <script id="template" type="x-tmpl-mustache">

  5. {{#isShow}}一{{/isShow}}

  6. {{^isShow}}二{{/isShow}}

  7. </script>

  8. //js部分

  9. <script type="text/javascript">

  10. var template = $("#template").html();

  11. var r = Mustache.render(template,{isShow:true}); //isShow存在且为布尔值true时,显示 “一”

  12. var r = Mustache.render(template,{isShow:false}); //isShow存在且为布尔值true时,显示 “二”

  13. var r = Mustache.render(template,{}); //isShow不存在时,显示 “二”

  14. var r = Mustache.render(template,{isShow:[]}); //isShow存在,为空数组时,显示 “二”

  15. var r = Mustache.render(template,{isShow:undefined}); //isShow存在,为undefined时,显示 “二”

  16. var r = Mustache.render(template,{isShow:null}); //isShow存在,为null时,显示 “二”

  17. $("#target").html(r)

  18. </script>

实际使用

用一个唯一id的script标签包裹模板内容,type类型为text/template

<script id="template" type="text/template"></script>

使用原生javascript方法或者jquery方法获得唯一id的script标签的html内容

var template = document.getElementById('template').innerHTML.trim();
//或
var template = $("#template").html();

使用mustache的render方法处理模板后填充到目标位置

var rendered = Mustache.render(template,obj);
$('#target').html(rendered)

完整代码如下:

 
  1. <!DOCTYPE html>

  2. <html lang="en">

  3. <head>

  4. <meta charset="UTF-8">

  5. <title>Document</title>

  6. </head>

  7. <body "loadUser()">

  8. <div id="target">Loading</div>

  9. <script id="template" type="x-tmpl-mustache">

  10. Hello {{}}~

  11. <ul>

  12. {{#list}}

  13. <li>{{name}}</li>

  14. {{/list}}

  15. </ul>

  16. </script>

  17. <script type="text/javascript" src="js/jquery-2.1.0.min.js"></script>

  18. <script type="text/javascript" src="js/mustache.js"></script>

  19. <script type="text/javascript">

  20. function loadUser(){

  21. var template = $("#template").html();

  22. var obj = {

  23. list:[

  24. {name:'wan'},

  25. {name:'wan'},

  26. {name:'wan'}

  27. ]

  28. }

  29. var rendered = Mustache.render(template,obj);

  30. $('#target').html(rendered)

  31. }

  32. </script>

  33. </body>

  34. </html>

上面示例是内部文件使用mustache模板引擎,我们还可以引入外部模板引擎来渲染页面。

首先我们在HTML文档中引入jquery.mustache.js文件配合mustache使用,jquery.mustache.js是jQuery做了一层封装,提供了集中方法让我们更方便使用mustache做模板渲染。 此处我们使用它的.load方法从指定路径加载模板文件,加载成功后使用$.Mustache.render()处理模板渲染页面。

$.Mustache.load('./mustache/demo2.mustache').done(function(){$("#target").html($.Mustache.render('demo2',{name:'wan'}))})
下面我们来看一个完整的案例
 
  1. <!DOCTYPE html>

  2. <html lang="en">

  3. <head>

  4. <meta charset="UTF-8">

  5. <title>Document</title>

  6. </head>

  7. <body>

  8. <div id="target">Loading</div>

  9. <script type="text/javascript" src="js/jquery-2.1.0.min.js"></script>

  10. <script type="text/javascript" src="js/mustache.js"></script>

  11. <script type="text/javascript" src="js/jquery.mustache.js"></script>

  12. <script type="text/javascript">

  13. //要传入的数据

  14. var objData = {

  15. list:[

  16. {name:'wannianqing',age:18,job:'The Front End'},

  17. {name:'wangxiaosan',age:19,job:'java'},

  18. {name:'lixiaosi',age:20,job:'The Front End'},

  19. {name:'sunxiaowu',age:21,job:'java'}

  20. ]

  21. }

  22. //加载模板方法

  23. function loadTemplateMustache(mustacheName,targetId,templateId,data){

  24. //模板路径

  25. var mustacheDir = './mustache/'+mustacheName+'.mustache';

  26. //渲染目标容器

  27. var targetContainer = $(targetId);

  28. if(targetContainer.length > 0){

  29. $.Mustache

  30. .load(mustacheDir) //加载模板文件

  31. .done(function(){

  32. //渲染模板

  33. renderTarget(targetContainer,templateId,data)

  34. })

  35. }

  36. }

  37. //渲染模板方法

  38. function renderTarget(dom,templateId,data){

  39. var el = dom;

  40. el.html('');

  41. el.append($.Mustache.render(templateId,data));

  42. }

  43. loadTemplateMustache('demo4','#target','template',objData)

  44. </script>

  45. </body>

  46. </html>

这篇关于js模板引擎mustache介绍及实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973027

相关文章

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}