DIY一个前端模板引擎.(一)
前端MVVM 模式有点很多,完全摆脱了意大利面条式的代码。
个人认为,所有MVVM 的框架基础就是一个高性能的JS模板引擎,它极大简化了 DOM 操作, 使页面渲染和业务逻辑彻底分离.
为了理解模板引擎原理(zhaungbi),所以我折腾了一个简化版的模板引擎.可以实现数据绑定,三元表达式, for 循环和 if 判断.
如何实现三元表达式, for 循环和 if 判断,将在下一篇介绍.
HTML 模板
下面是我定义好的html 模板字符串。
var template = `
<div>
<span>
{{number}}
</span>
</div>
`;
这是我的数据
var scope ={
number:10
}
好了,现在怎么把数据渲染到模板上面呢?
很自然的想到 正则表达式
正则替换
第一步 ,可以使用字符串的replace 函数。
这是正则
var regex = /\{\{([A-Za-z_\$]+[A-Za-z0-9_\$]*)\}\}/g;
好了,现在编写一个函数,我把我的模板引擎就叫 SS。
var SS = (function() {
var regex = /\{\{([A-Za-z_\$]+[A-Za-z0-9_\$]*)\}\}/g;
var result = "";
var ss = {};
ss.Render = function(template, scope) {
result = template.replace(regex, function(a, b) {
b = b.trim();
return scope[b];
})
return result;
}
return ss;
})()
测试一下
SS.Render(template,scope);
这是结果
但是,仅仅渲染一级属性的模板引擎有什么用呢?
渲染多级属性
在这里,渲染多级属性还是分为两种。
- 变量属性 (不知道这么称是否准确,就是类似于 person.name)
- 数组属性 (数组元素,key 必须是数字类型)
这里,先解决变量属性
变量属性
首先,需要一个新的正则表达式
var regex = /\{\{([A-Za-z_\$]+(\.[A-Za-z_\$]+|[A-Za-z0-9_\$])*)\}\}/g;
正则写的很烂,如果发现错误希望不吝赐教
html 模板
var template =
`
<div>
{{title}}
<ul>
<li>{{item.name}}</li>
<li>{{item.age}}</li>
<ul/>
<div>
`
按照上面模板匹配的数据
var scope = {
title:"hello",
item:{
name:'pawn',age:15
}
}
渲染函数
ss.Render = function(template, scope) {
result = template.replace(regex, function($, $1) {
$1 = $1.trim();
var innerdata = scope;
var items = $1.split('.');
for (var i = 0; i < items.length; i++) {
innerdata = innerdata[items[i]];
}
return innerdata;
});
return result;
}
在这里考虑到元素的属性,所以将{{}} 中包含字符'.' 也匹配出来,再使用'.'分割,然后依次向下寻找
测试代码
var res = ss.Render(template, scope);
console.log(res);
这是结果:
貌似这个模板引擎已经具有雏形了
数组属性
在这里,要是正则能够匹配上[] ,而且里面必须是数字
var regex = /\{\{([A-Za-z_\$]+(\[\d+\]+|\.[A-Za-z_\$]+|[A-Za-z0-9_$])*)\}\}/g;
这个正则主要是匹配形如 items[0].name 类型.
变量名必须是字母下划线或者$ 符号打头,后面必须是 [],.[A-Za-z_\$] 或者
[A-Za-z0-9_$]
如果正则有错,还忘各位不吝赐教.
形如,items[0].name.a.b 中,可以使用'.' 来分割字符串,然后进行迭代找到最终数据.
在每一次迭代中,可以使用 /[\d+]/.test(items[i]) 来判断是否包含'[]',如果包含,那么使用/[\d+]/循环匹配取出其中每一项.
总体代码就是这样
ss.Render = function (template, scope) {
result = template.replace(regex, function ($, $1) {
$1 = $1.trim();
var innerdata = scope;
var items = $1.split('.');
for (var i = 0; i < items.length; i++) {
var m;
if (/\[\d+\]/.test(items[i])) {
innerdata = innerdata[items[i].split('[')[0]];
var reNumber = /\[(\d+)\]/g;
while (m = reNumber.exec(items[i])) {
innerdata = innerdata[m[1]];
}
}
else {
innerdata = innerdata[items[i]];
}
}
return innerdata;
});
html 模板
var template =
`<div>
{{title}}
<ul>
<li>
name:{{items[0].name}}
<br />
age:{{items[0].age}}
<br />
sex:{{items[0].sex}}
</li>
<li>
name:{{items[1].name}}
<br />
age:{{items[1].age}}
<br />
sex:{{items[1].sex}}
</li>
<ul/>
<div>
`;
模板数据
var scope = {
title: "person list",
items: [{
name: 'pawn',
age: 21,
sex: 1
}, {
name: 'jk',
age: 30,
sex: 0
},]
}
测试
console.log(SS.Render(template, scope));
结果
结束
SS 模板中简单的数据绑定就已经实现.
在 SS 前端模板引擎.(二) 中会插入 三元表达式,for循环和if条件判断
DIY一个前端模板引擎.(一)的更多相关文章
- SS - DIY一个前端模板引擎.(一)
前端MVVM 模式有点很多,完全摆脱了意大利面条式的代码. 个人认为,所有MVVM 的框架基础就是一个高性能的JS模板引擎,它极大简化了 DOM 操作, 使页面渲染和业务逻辑彻底分离. 为了理解模板引 ...
- Mustache.js前端模板引擎源码解读
mustache是一个很轻的前端模板引擎,因为之前接手的项目用了这个模板引擎,自己就也继续用了一会觉得还不错,最近项目相对没那么忙,于是就抽了点时间看了一下这个的源码.源码很少,也就只有六百多行,所以 ...
- JST(JavaScript Trimpath)前端模板引擎简介
JST(JavaScript Trimpath)前端模板引擎简介及应用 今天在做某系统日志列表的时候用到了这个玩意儿.刚开始只是根据别人的例子照葫芦画瓢完成了日志列表及对应详情,晚上有空了才仔细去网上 ...
- artTemplate-优秀的前端模板引擎
artTemplate-优秀的前端模板引擎 1.html中引入artTemplate的js文件: <script type="text/javascript" src=&qu ...
- 前端模板引擎doT.js的用法
简介 一款简单好用的前端模板引擎 用法 <script type="text/javascript" src="js/doT.min.js">< ...
- jquery template.js前端模板引擎
作为现代应用,ajax的大量使用,使得前端工程师们日常的开发少不了拼装模板,渲染模板 在刚有web的时候,前端与后端的交互,非常直白,浏览器端发出URL,后端返回一张拼好了的HTML串.浏览器对其进行 ...
- 前端模板引擎artTemplate.js
. 关于artTemplate模板引擎的详细原理请移步高性能JavaScript模板引擎原理解析,本文只探讨如何使用.初学前端的人一般对于绑定数据都是使用原生js或者jquery来拼接字符串,此为ha ...
- 前端模板引擎doT.js的使用
前言 我们在做前端开发时,经常需要根据后台返回的json数据动态生成html并插入到页面中显示.最简单的方法就是通过jQuery去遍历数据拼接html,如以下: <script> var ...
- Java 前端模板引擎学习:thymeleaf 模板引擎
模板引擎接口 ITemplateEngine 一.后台数据与外部数据 1.处理后台数据 $表达式是个变量表达式,用于处理在 request parameters and the request, s ...
随机推荐
- H5前端性能测试快速入门
前言 说到H5测试,对于做WEB测试的同学来说再熟悉不过了,它包括页H5功能测试,前端性能测试,浏览器兼容性能测试,以及服务端性能测试.那本文谈到的则是H5前端性能测试,并希望通过阅读本文后,能够知道 ...
- easyui tree onloadsuccess事件的心得
在onloadSuccess事件中不能apeed新节点,否则又会触发noloadsuccess事件,形成死循环. 公司电话:028-87657875 13060063607 淘宝店 ...
- 【转】Beanstalkd 队列简易使用
Beanstalkd一个高性能分布式内存队列系统 之前在微博上调查过大家正在使用的分布式内存队列系统,反馈有Memcacheq,Fqueue, RabbitMQ, Beanstalkd以及link ...
- checkbox、全选反选,获取值
<input id="Chk_All" onclick="CheckAll()" type="checkbox" /> < ...
- JAVA 异常类
1.Exception(异常) :是程序本身可以处理的异常. 2.Error(错误): 是程序无法处理的错误.这些错误表示故障发生于虚拟机自身.或者发生在虚拟机试图执行应用时,一般不需要程序处理. 3 ...
- 学习codeIgniter的一点小感受
用CI好几天了,最终还是放弃用CI做完整的项目,感觉CI在前后端的交互上还比较差,比如说用户表单验证,仍然是需要把数据提交给服务器之后才能显示逻辑判断的结果.而这一点明显是相对落后了. 但不可否认CI ...
- linux下rm -r误删NTFS文件恢复方法
一时疏忽,手一抖,把整个挂载的F盘删了一半!顿时傻眼!! 被删的F盘是Windows下NTFS分区,在Ubuntu12.04中挂载了F盘,使用rm命令时粗心大意,误删了一半的数据. 血的教训告诉我们, ...
- Android应用:横竖屏切换总结
眨眼间,已经到了2016你年春节前,离上一篇博客的时间已经有6个月多,回想起这半年的种种,不得不说,学习和工作实在是太忙了,或许这就是程序员的真实写照吧. 写博客之初,主要的目的还是为了把自己的学习痕 ...
- Mini projects #8–RiceRocks
课程全名:An Introduction to Interactive Programming in Python,来自 Rice University 授课教授:Joe Warren, Scott ...
- 打包java项目为可执行程序(exe)
一直都是编写了java程序后在控制台 javac --> java 命令运行,或者在eclipse中运行,今天突然想怎么可以写好了一个项目随处可以运行呢? 于是网上搜了步骤,跟着一步一步实现了, ...