位置: 编程技术 - 正文

详解Javascript模板引擎mustache.js(js 模块 modules)

编辑:rootadmin

推荐整理分享详解Javascript模板引擎mustache.js(js 模块 modules),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript demo,javascript 模块,javascript demo,javascript modules,javascript module,js模块的使用规则,js模块的使用规则,javascript mod,内容如对您有帮助,希望把文章链接给更多的朋友!

本文总结它的使用方法和一些使用心得,内容不算很高深,纯粹是入门内容,看看即可。不过要是你还没有用过此类的javascript引擎库,那么本文还是值得你一读的,相信在你了解完它强大的功能和简单用法之后,一定会迫不及待地将之用于你的工作当中。

1. 从一个简单真实的需求讲起目前公司做了一个统一的开发平台,后台封装了MVC的接口和数据增删改查的接口,前端我自己用bootstrap+手写各类组件的方式弄了一套开发框架;集成了CAS,在CAS的基础上,首先做了一套统一权限管理系统,这个系统是我们开发平台的第一个子系统,用来管理配置所有子系统的菜单和授权以及管理整个公司的组织结构和用户,后来我们又陆陆续续地开发了业务系统A和业务系统B。由于这三个子系统对应的是三个java工程,最终部署的时候,在tomcat里部署了三个应用,现在有一个需求是:

1)在每个系统里登录之后,点击系统名称,可以展开一个下拉菜单,显示所有有权限的子系统; 2)然后用户点击其它子系统,就可以切换到所选中的系统去,到了其它系统之后,由于都做了这个下拉菜单,所以也可以再从该系统切换回来; 3)如果用户只有一个系统的权限,则不显示下拉菜单。

需求其实挺简单,原型大概是这个样子:

功能实现方法是,在每个子系统登录完成之后,调用获取系统列表的接口,用js渲染一个下拉菜单出来,该接口返回的格式为:

如果我们不采用模板引擎,那么传统的方式去解析这个数据并把它转变成html串的方法通常是:

这种拼接字符串的方式有诸多弊端:

1)麻烦,尤其是拼接逻辑复杂,拼接的串很长时; 2)不易维护,稍有不慎就会弄错标签的对应关系; 3)结构不清晰。

能够简化这个场景的工具就是模板引擎,模板引擎的技术后台最先有,如果你用过jsp,就一定知道jsp也就是一个模板,用来解析呈现数据用的,其它后台模板引擎还有velocity和freemarker等等。前端的模板引擎也有很多,mustache.js算是比较流行的一个,git上有多个赞,如果这个问题我们用mustache.js来做,就可以变成这样:

对比两个代码,会发现后面的代码,相对于前面的有以下这些优点:

1)结构清晰,所有待渲染的html都定义在一个位置,而且没有任何拼接的现象; 2)逻辑清晰,那些在模板里的标记,实际上与模板渲染时传进去的对象的属性名称都是对应的; 3)易维护,要增删标签都只用调整模板对应的数组就行了。

通过这个例子,应该能对模板引擎有了一个大概的认识,这类工具在前端开发中越来越普遍,尤其是前后端分离的应用中用的更多,已经是这类应用的基础架构的内容了。mustache.js是一个非常简单易用的引擎实现,接下来的内容将会对这个工具常用的模板配置一一介绍并配合实用的例子说明,希望能让你更喜欢这个工具:)

2. mustache的用法mustache的使用非常简单,先通过script标签引入它的js文件,然后按下面的步骤操作: 1)定义模板字符串 定义模板有2种方式,方式一就是在前面部分中看到的,直接用[...].join('')的方式在js代码中定义,方式二直接把模板内容用script定义在html中:

然后在编译模板之前,通过获取tpl的innerHTML定义原始模板串:

具体要用哪种方式来定义模板,可以参考下面的建议: 如果这个模板要用于多个页面,推荐把模板定义在js代码中;如果这个模板只用于当前页面,推荐直接定义到script标签中,管理更方便。 2)预编译模板 假设原始模板串已经定义好,并用tpl变量来引用,就可以通过下面的代码来预编译模板:

要注意的是,经过预编译之后的tpl已经不再是原来的模板串了,连数据类型都变成数组类型了,这都是预编译的结果。 3)渲染模板 渲染方式很简单:

obj引用的是一个数据源对象,mustache会把模板中那些属性标签,根据约定的规则,替换成对象的内容。htmlAfterRendered就是替换之后的字符串,你可以用它完成你需要的DOM操作。

3. mustache的思想mustache的核心是标签和logic-less。从前面的代码中可以看到定义模板时,使用了{{name}}这样的标记,还有{{#systems}}{{/systems}},这就是mustache的标签,只不过它用{{}}替代了<>,以免跟html标签的<>混淆。logic-less,可以翻译为轻逻辑,因为在定义模板的时候不会用到if-else,不会有循环式的编码,一切都用标签来解决,它的标签非常简单,但是能应付所有场景,阅读完本文之后,你会惊讶地发现,只要用以下几个标签几乎就能解决所有的问题: {{prop}} {{{prop}}} {{#prop}}{{/prop}} {{^prop}}{{/prop}}

4. {{prop}}标签这个标签是mustache模板里用的最多的,可以将数据源对象上prop属性对应的值,转换成字符串进行输出,以下是同一个属性,对应不同类型的值,在经过mustache渲染之后输出结果的测试(前后那根短横线的作用是为了让这个标签的渲染结果看起来更清楚):

详解Javascript模板引擎mustache.js(js 模块 modules)

mustache渲染{{prop}}标签的逻辑是:

1)如果prop引用的值是null或undefined,则渲染成空串; 2)如果prop引用的是一个函数,则在渲染时自动执行这个函数,并把这个函数的返回值作为渲染结果,假如这个返回值为null或者undefined,那么渲染结果仍然为空串,否则把返回值转成字符串作为渲染结果(注意最后一个用例,直接把函数代码渲染出来了); 3)其它场景,直接把prop引用的值转成字符串作为渲染结果。

由于默认情况下,mustache在渲染prop时,都是对prop的原始值进行url编码或者html编码之后再输出的,所以有一个用例的渲染结果,把英文的单引号,转成了html实体符:

如果要阻止这种编码行为,只要把标签形式改成{{{prop}}}就可以了:

5. {{#prop}}{{/prop}}标签这对标签的作用非常强大,可以同时完成if-else和for-each以及动态渲染的模板功能。在这对标签之间,可以定义其它模板内容,嵌套所有标签。接下来看看mustache如何利用这个对标签完成这三个模板功能。

1) if-else渲染

只有prop属性在数据源对象上存在,并且不为falsy值(javascript 6个falsy值:null,undefined,NaN,0,false,空字符串),并且不为空数组的情况下,标签之间的内容才会被渲染,否则都不会被渲染:

以上用例中特殊点的就是prop属性引用的是一个函数的时候,{{#prop}}会自动调用这个函数,并把函数的返回值作为if-else渲染逻辑的判断依据,也就是说如果这个函数返回的是falsy值或者是空数组的时候,那么这对标签之间的内容还是不会显示。

2)for-each渲染

当prop属性所引用的是一个非空数组时,这对标签之间的内容将会根据数组大小进行迭代,并且当数组元素为对象时,还会把该对象作为每一次迭代的上下文,以便迭代时的标签可以直接引用数组元素上的属性:

从这个测试结果中可以看到,{{#prop}}{{/prop}}之间的模板内容根据prop所引用的数组迭代了两次,并且在这对标签内部直接通过{{name}}标签,输出了数组元素对象上的name属性对应的值。

如果prop属性所引用的是一个函数,但是这个函数返回值是一个数组类型,那么仍然会进行for-each渲染:

3) 动态渲染

当prop属性所引用的是一个函数,并且这个函数的返回值还是一个函数的话,mustache会再次调用这个返回的函数,并给它传递2个参数:text表示原来的模板内容,render表示mustache内部的执行渲染的对象,以便在这个函数内部可以通过这render对象,结合原来的模板内容,自定义渲染的逻辑,并把函数的返回值作为渲染结果(这个返回值渲染的逻辑跟{{prop}}标签完全一样):

6. {{^prop}}{{/prop}}标签这对标签,与{{#prop}}{{/prop}}的if-else渲染执行相反逻辑,即只有在prop属性不存在,或者引用的是一个falsy值,或者是一个空数组的时候才会显示标签之间的内容,否则不会显示:

7. 渲染上下文mustache有一个渲染上下文栈的概念,在模板渲染的开始的时候,把数据源对象作为当前的渲染上下文 ,并压入上下文栈。在遇到{{#prop}}标签的时候,如果prop引用的是一个对象或者是一个非空的对象数组,或者prop引用的是一个函数,并且这个函数返回的是一个对象或者是一个非空的对象数组,就会把这个对象或者数组的元素作为当前渲染上下文,并压入上下文栈,当这个标签渲染完毕的时候,才会把该上下文弹出,恢复上一层标签所使用的上下文。由于{{#prop}}标签可以多层嵌套,所以在有的模板渲染的时候,会有多层上下文存在。mustache在解析标签时,根据标签名称查找当前上下文对象是否存在该属性,如果不存在就会到上层上下文对象中查找,只要在某一层找到,就会用该层上下文对象的值来渲染。

上面这个例子中,在渲染{{#address}}{{/address}}时,上下文对象已经变成了obj2.person.student.address所引用的对象,所以{{home}}渲染时用到的就是obj2.person.student.address.home属性,而{{age}}渲染时,由于obj2.person.student.address不存在age属性,所以就会到上层上下文中查找,一直到obj2对象才找到,于是就把obj2.age当成了渲染结果。

还有一种方法,不用通过{{#prop}}创建新的上下文,也可以做到递归渲染属性的属性:

这种方法其实很好理解,只要知道当前的上下文对象,再根据属性操作串person.student.address.home,当然就能找到需要的值了。

本文介绍了一个非常好用的前端模板引擎,涵盖的内容包含了在日常工作肯定会用到的知识点,希望大家喜欢。

高性能JavaScript循环语句和条件语句 一、循环语句众所周知,常用的循环语句有for、while、do-while以及for-in,forEach。除了for-in和forEach性能略低外,平时我们对前三者的选择更多的是基于需

学习JavaScript设计模式之模板方法模式 一、定义模板方法是基于继承的设计模式,可以很好的提高系统的扩展性。java中的抽象父类、子类模板方法有两部分结构组成,第一部分是抽象父类,

属于你的jQuery提示框(Tip)插件 插件可以满足常用的提示显示,支持个方向,支持边框、背景色、文本颜色自定义,支持位置微调、层级微调、宽度间距等参数调整。先看看效果:tip

标签: js 模块 modules

本文链接地址:https://www.jiuchutong.com/biancheng/383745.html 转载请保留说明!

上一篇:JavaScript优化专题之Loading and Execution加载和运行(js优化108条建议)

下一篇:高性能JavaScript循环语句和条件语句(高性能javascript的内容简介)

  • 新公司税务报到网上操作流程
  • 工程劳务费计入哪个会计科目
  • 利息费用和利息支出的区别计算公式
  • 其他应收款平账怎么做分录
  • 资产负债表中应付职工薪酬是负数
  • 人工费能不能抵扣进项税
  • 福利费进项税转出的会计分录
  • 进口增值税和进项税
  • 研发加计扣除减免税
  • 商誉减值可以抵税吗
  • 样板房 家具
  • 法人购买设备怎么入账
  • 装修计入固定资产
  • 阿里云增值税专用发票
  • 统借统还如何缴纳增值税
  • 物业管理提供的服务变化
  • etc发票犯法吗
  • 小规模企业资本结构
  • 税务师几年内考完几门
  • 个人承担的社保费用算在员工工资里吗?
  • 停车管理费什么时候交
  • 管理费用月末结账
  • 增值税多交了怎么申请退税
  • 银行承兑汇票到期后多长时间失效
  • 苗木免税票能随便开吗
  • 索赔发票会计入账
  • 现金日记账有哪几种
  • 企业合并怎么处理
  • 上月留抵进项抵扣分录
  • 植物租赁方案
  • 戛纳,法国 (© Manjik Photography/Alamy)
  • php 字符串函数
  • 资产减值准备为什么在贷方
  • 购进的货物
  • 加速折旧法计算公式 CFA
  • PHP:json_last_error_msg()的用法_JSON函数
  • 摊销无形资产会影响无形资产的账面价值吗
  • Aerial view of Chapel Bridge over the river Reuss in Lucerne, Switzerland (© Neleman Initiative/Gallery Stock)
  • 能用javascript 最终
  • 人工智能大模型上市公司
  • 库存现金每月终了由谁清点
  • 如何查看python模块的依赖包
  • 支付厂房租赁费怎么入账
  • 销售免税农产品如何开票
  • 公司开电费发票该怎么入账?
  • 资产负债表应付职工薪酬是负数是什么原因
  • 公款私存个人检讨
  • 上缴非税收入的税种
  • 一般纳税人企业所得税税率多少
  • 电费应收和实收怎么算
  • 购入农产品的增值税税率是多少
  • 怎样在excel计算
  • 实缴出资未注明投资款
  • 小规模纳税人劳务费税率
  • 配件盘点出现盘盈盘亏后如何处理
  • 专用发票冲红有时间有时间限制吗
  • 到期不付款跟客户怎么说
  • 发票认证是为了什么
  • 收到税务局退还的个税手续费怎么入账
  • MySQL Index Condition Pushdown(ICP)性能优化方法实例
  • mysql安装配置教程5.7.25
  • linux 主力机
  • win10商店是什么
  • windowxp一直在windowxp界面
  • Windows正在启动卡死
  • win7开机后一段时间卡死
  • win8取消开始界面
  • 简述linux的系统结构
  • cocoscreator lua
  • Bootstrap与KnockoutJs相结合实现分页效果实例详解
  • Unity3D游戏开发标准教程吴亚峰于复兴人民邮电出版社
  • opengl矩形
  • unity linux arm
  • js控制display属性
  • 源码分析工具
  • 安卓手机管家下载
  • JavaScript While 循环 教程
  • 开票系统怎么设置默认税率
  • 怎样把短信转发到微信
  • 白酒消费税应纳税额
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设