前端MVVM 模式有点很多,完全摆脱了意大利面条式的代码。

个人认为,所有MVVM 的框架基础就是一个高性能的JS模板引擎,它极大简化了 DOM 操作, 使页面渲染和业务逻辑彻底分离.

为了理解模板引擎原理(zhaungbi),所以我折腾了一个简化版的模板引擎.可以实现数据绑定,三元表达式, for 循环和 if 判断.

如何实现三元表达式, for 循环和 if 判断,将在下一篇介绍.

HTML 模板

下面是我定义好的html 模板字符串。

  1. var template = `
  2. <div>
  3. <span>
  4. {{number}}
  5. </span>
  6. </div>
  7. `;

这是我的数据

  1. var scope ={
  2. number:10
  3. }

好了,现在怎么把数据渲染到模板上面呢?

很自然的想到 正则表达式

正则替换

第一步 ,可以使用字符串的replace 函数。

这是正则

  1. var regex = /\{\{([A-Za-z_\$]+[A-Za-z0-9_\$]*)\}\}/g;

好了,现在编写一个函数,我把我的模板引擎就叫 SS。

  1. var SS = (function() {
  2. var regex = /\{\{([A-Za-z_\$]+[A-Za-z0-9_\$]*)\}\}/g;
  3. var result = "";
  4. var ss = {};
  5. ss.Render = function(template, scope) {
  6. result = template.replace(regex, function(a, b) {
  7. b = b.trim();
  8. return scope[b];
  9. })
  10. return result;
  11. }
  12. return ss;
  13. })()

测试一下

  1. SS.Render(template,scope);

这是结果

但是,仅仅渲染一级属性的模板引擎有什么用呢?

渲染多级属性

在这里,渲染多级属性还是分为两种。

  • 变量属性 (不知道这么称是否准确,就是类似于 person.name)
  • 数组属性 (数组元素,key 必须是数字类型)

这里,先解决变量属性

变量属性

首先,需要一个新的正则表达式

  1. var regex = /\{\{([A-Za-z_\$]+(\.[A-Za-z_\$]+|[A-Za-z0-9_\$])*)\}\}/g;

正则写的很烂,如果发现错误希望不吝赐教

html 模板

  1. var template =
  2. `
  3. <div>
  4. {{title}}
  5. <ul>
  6. <li>{{item.name}}</li>
  7. <li>{{item.age}}</li>
  8. <ul/>
  9. <div>
  10. `

按照上面模板匹配的数据

  1. var scope = {
  2. title:"hello",
  3. item:{
  4. name:'pawn',age:15
  5. }
  6. }

渲染函数

  1. ss.Render = function(template, scope) {
  2. result = template.replace(regex, function($, $1) {
  3. $1 = $1.trim();
  4. var innerdata = scope;
  5. var items = $1.split('.');
  6. for (var i = 0; i < items.length; i++) {
  7. innerdata = innerdata[items[i]];
  8. }
  9. return innerdata;
  10. });
  11. return result;
  12. }

在这里考虑到元素的属性,所以将{{}} 中包含字符'.' 也匹配出来,再使用'.'分割,然后依次向下寻找

测试代码

  1. var res = ss.Render(template, scope);
  2. console.log(res);

这是结果:

貌似这个模板引擎已经具有雏形了

数组属性

在这里,要是正则能够匹配上[] ,而且里面必须是数字

  1. 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+]/循环匹配取出其中每一项.

总体代码就是这样

  1. ss.Render = function (template, scope) {
  2. result = template.replace(regex, function ($, $1) {
  3. $1 = $1.trim();
  4. var innerdata = scope;
  5. var items = $1.split('.');
  6. for (var i = 0; i < items.length; i++) {
  7. var m;
  8. if (/\[\d+\]/.test(items[i])) {
  9. innerdata = innerdata[items[i].split('[')[0]];
  10. var reNumber = /\[(\d+)\]/g;
  11. while (m = reNumber.exec(items[i])) {
  12. innerdata = innerdata[m[1]];
  13. }
  14. }
  15. else {
  16. innerdata = innerdata[items[i]];
  17. }
  18. }
  19. return innerdata;
  20. });

html 模板

  1. var template =
  2. `<div>
  3. {{title}}
  4. <ul>
  5. <li>
  6. name:{{items[0].name}}
  7. <br />
  8. age:{{items[0].age}}
  9. <br />
  10. sex:{{items[0].sex}}
  11. </li>
  12. <li>
  13. name:{{items[1].name}}
  14. <br />
  15. age:{{items[1].age}}
  16. <br />
  17. sex:{{items[1].sex}}
  18. </li>
  19. <ul/>
  20. <div>
  21. `;

模板数据

  1. var scope = {
  2. title: "person list",
  3. items: [{
  4. name: 'pawn',
  5. age: 21,
  6. sex: 1
  7. }, {
  8. name: 'jk',
  9. age: 30,
  10. sex: 0
  11. },]
  12. }

测试

  1. console.log(SS.Render(template, scope));

结果

结束

SS 模板中简单的数据绑定就已经实现.

在 SS 前端模板引擎.(二) 中会插入 三元表达式,for循环和if条件判断

SS - DIY一个前端模板引擎.(一)的更多相关文章

  1. DIY一个前端模板引擎.(一)

    前端MVVM 模式有点很多,完全摆脱了意大利面条式的代码.个人认为,所有MVVM 的框架基础就是一个高性能的JS模板引擎,它极大简化了 DOM 操作, 使页面渲染和业务逻辑彻底分离.为了理解模板引擎原 ...

  2. Mustache.js前端模板引擎源码解读

    mustache是一个很轻的前端模板引擎,因为之前接手的项目用了这个模板引擎,自己就也继续用了一会觉得还不错,最近项目相对没那么忙,于是就抽了点时间看了一下这个的源码.源码很少,也就只有六百多行,所以 ...

  3. JST(JavaScript Trimpath)前端模板引擎简介

    JST(JavaScript Trimpath)前端模板引擎简介及应用 今天在做某系统日志列表的时候用到了这个玩意儿.刚开始只是根据别人的例子照葫芦画瓢完成了日志列表及对应详情,晚上有空了才仔细去网上 ...

  4. artTemplate-优秀的前端模板引擎

    artTemplate-优秀的前端模板引擎 1.html中引入artTemplate的js文件: <script type="text/javascript" src=&qu ...

  5. 前端模板引擎doT.js的用法

    简介 一款简单好用的前端模板引擎 用法 <script type="text/javascript" src="js/doT.min.js">< ...

  6. 前端模板引擎artTemplate.js

    . 关于artTemplate模板引擎的详细原理请移步高性能JavaScript模板引擎原理解析,本文只探讨如何使用.初学前端的人一般对于绑定数据都是使用原生js或者jquery来拼接字符串,此为ha ...

  7. jquery template.js前端模板引擎

    作为现代应用,ajax的大量使用,使得前端工程师们日常的开发少不了拼装模板,渲染模板 在刚有web的时候,前端与后端的交互,非常直白,浏览器端发出URL,后端返回一张拼好了的HTML串.浏览器对其进行 ...

  8. 前端模板引擎doT.js的使用

    前言 我们在做前端开发时,经常需要根据后台返回的json数据动态生成html并插入到页面中显示.最简单的方法就是通过jQuery去遍历数据拼接html,如以下: <script> var ...

  9. Java 前端模板引擎学习:thymeleaf 模板引擎

    模板引擎接口 ITemplateEngine 一.后台数据与外部数据 1.处理后台数据 $表达式是个变量表达式,用于处理在  request parameters and the request, s ...

随机推荐

  1. css3 filter的十种特效

    filter默认值是none,他不具备继承性,其中filter-function具有一下属性: grayscale灰度 sepia褐色(求专业指点翻译) saturate饱和度 hue-rotate色 ...

  2. Apache InterfaceAudience

    InterfaceAudience 类包含三个注解类型,用来被说明被他们注解的类型的潜在的使用范围(audience).@InterfaceAudience.Public: 对所有工程和应用可用@In ...

  3. easyui-conbotree树形下拉框。。。转

    最近一直在研究这个树形的下拉选择框,感觉非常的有用,现在整理下来供大家使用: 首先数据库的表架构设计和三级菜单联动的表结构是一样,(父子关系) 1.下面我们用hibernate建一下对应的额实体类: ...

  4. 基于webdriver的jmeter性能测试-Eclipse+Selenium+JUnit生成jar包

    续接 打开eclipse新建java项目,如下图所示: 输入项目名称后点击"完成"按钮,如下图所示: eclipse中新建一个java项目,如下图所示: 添加类库,如下图所示: 在 ...

  5. HDU2433 BFS最短路

    Travel Time Limit: 10000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  6. SSE: server-sent events

    当客户端需要定时轮询服务器获取一些消息的时候,可以使用 servser-sent events .NET 服务端: public void ProcessRequest(HttpContext con ...

  7. MyBatis的经典案例

    1.首先我们先了解Mybatis的一些jar包 ---和项目框架 2.接下来就看看mybatis的配置文件(mybatis-config.xml) <?xml version="1.0 ...

  8. listview嵌套gridview,并实现grid元素部分显示以及点击展开与折叠

    原文链接:http://blog.csdn.net/duguju/article/details/49538341 有时我们需要用GridView显示目录列表,有时甚至是二级的,即listview每一 ...

  9. ASP.NET vNext 概述

    兼容Mono的下一代云环境Web开发框架ASP.NET vNext 我们知道了ASP.NET vNext是一个全新的框架,是一个与时俱进的框架.这篇文章将深入讨论在整体架构更多的细节,文档参照 ASP ...

  10. 利用history实现无刷新跳转界面

    看标题是不是感觉很拽的样子,其实没什么啦,也就是时下常说的单页面应用.这种web形式在如今的移动端十分流行,毕竟在移动端频繁得去刷新界面不是很友好,而且还费流量.今天我们要做一个小的app(移动端), ...