mustache模板引擎学习记录

2024-04-06 15:12

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

0.历史上曾经出现的数据变为视图的方法

        1.纯DOM法
let arr = [{"name":"张三","age":18,"sex":"男"},
]
let list = document.querySelector('#list')
for (let i = 0; i < arr.length; i++) {let li = document.createElement('li')li.innerHTML = "<div>"+arr[i].name+"</div>"list.appendChild(li)    
}
        2.数组join法
let arr = [{"name":"张三","age":18,"sex":"男"},
]
let list = document.querySelector('#list')
for (let i = 0; i < arr.length; i++) {list.innerHTML += ["<li>"+arr[i].name+"</li>"].join("")
}
        3.ES6的反引号法
let arr = [{"name":"张三","age":18,"sex":"男"},
]
let list = document.querySelector('#list')
for (let i = 0; i < arr.length; i++) {list.innerHTML += `<div>姓名:${arr[i].name}</div>`
}
        4.模板引擎
let templateStr = `<div>姓名:${arr[i].name}</div>
`
let data = {arr:[{"name":"张三","age":18,"sex":"男"},{"name":"李四","age":20,"sex":"女"},{"name":"王五","age":22,"sex":"男"},]   
}
let domStr = Mustache.render(templateStr,data);
let container = document.querySelector("#container");
container.innerHTML = domStr;

1.简易正则实现模板匹配

let templateStr = "<h1>我买了一个{{ thing }} , 好{{ feeling }}</h1>"
let data = {thing: '华为手机',feeling: '开心'
}
console.log(templateStr.replace(/\{\{(.*?)\}\}/g, function(_,g) {return data[g.trim()]
}));

        封装成函数

let templateStr = "<h1>我买了一个{{ thing }} , 好{{ feeling }}</h1>"
let data = {thing: '华为手机',feeling: '开心'
}
function render(templateStr, data) {return templateStr.replace(/\{\{(.*?)\}\}/g, function(_,g) {return data[g.trim()]})
}
console.log(render(templateStr, data))

2.tokens

        tokens是一个JS的嵌套数组,模板字符串的JS表示

        它是“抽象语法树”,“虚拟节点”等等的开山鼻祖

        例:

                模板字符串

<h1>我买了一个{{thing}}</h1>

                tokens

let tokens =[{ type: 'text', value: '<h1>我买了一个' },{ type: 'name', value: 'thing' },{ type: 'text', value: '</h1>' },
]

        模板字符串 -> tokens + 数据 -> 正常标签

3.1.实现Scanner方法

/* 扫描器类 */
export default class Scanner {constructor(templateStr) {this.templateStr = templateStr;// 指针this.pos = 0;// 尾巴this.tail = this.templateStr.substring(this.pos);//*例:<h1>abc</h1>//*指针位:<//*尾巴:<h1>abc</h1>}// 扫描器扫描方法,走过指定内容,没有返回值scan(tag) {// 判断是否扫描到标签if (this.tail.indexOf(tag) == 0) {// 扫描到标签this.pos += tag.length   //*跳过标签  }}//让指针进行扫描,直到遇见指定内容结束,并且能够返回结束之前路过的文字scanUtil(stopTag) {//记录一下执行本方法的时候pos的值const pos_backup = this.pos;    //*这里记录起始位置 , //当尾巴的开头不是stopTag的时候,一直扫描 , 先判断有没有超出长度while (!this.eos() && this.tail.indexOf(stopTag) != 0) {this.pos++;//改变尾巴为从当前指针这个字符开始,到最后的全部字符this.tail = this.templateStr.substring(this.pos);}return this.templateStr.substring(pos_backup, this.pos);//返回结束之前路过的文字}//指针是否已经到头,返回布尔值  end of stringeos() {return this.pos >= this.templateStr.length;//如果指针已经大于等于字符串长度,返回true,否则返回false}
}

        图例

                获取指针 和 尾巴

                当尾巴的{{在第0位时,跳过模板长度,并赋上新尾巴

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


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/880165

相关文章

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

MySQL 存储引擎 MyISAM详解(最新推荐)

《MySQL存储引擎MyISAM详解(最新推荐)》使用MyISAM存储引擎的表占用空间很小,但是由于使用表级锁定,所以限制了读/写操作的性能,通常用于中小型的Web应用和数据仓库配置中的只读或主要... 目录mysql 5.5 之前默认的存储引擎️‍一、MyISAM 存储引擎的特性️‍二、MyISAM 的主

SpringBoot实现文件记录日志及日志文件自动归档和压缩

《SpringBoot实现文件记录日志及日志文件自动归档和压缩》Logback是Java日志框架,通过Logger收集日志并经Appender输出至控制台、文件等,SpringBoot配置logbac... 目录1、什么是Logback2、SpringBoot实现文件记录日志,日志文件自动归档和压缩2.1、

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de

使用nohup和--remove-source-files在后台运行rsync并记录日志方式

《使用nohup和--remove-source-files在后台运行rsync并记录日志方式》:本文主要介绍使用nohup和--remove-source-files在后台运行rsync并记录日... 目录一、什么是 --remove-source-files?二、示例命令三、命令详解1. nohup2.

Java如何根据word模板导出数据

《Java如何根据word模板导出数据》这篇文章主要为大家详细介绍了Java如何实现根据word模板导出数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... pom.XML文件导入依赖 <dependency> <groupId>cn.afterturn</groupId>

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财