利用art.template模仿VUE 一次渲染多个模版
TypeScript代码
import template = require('art-template/lib/template-web'); interface TemplateBindConfig {
el: string
data: object
} interface TemplateList {
els: object
template: string
} class TmpBind { el: string template: any data: object renderFn: any // 构造函数
constructor(config:TemplateBindConfig) {
// 绑定的容器id
this.el = config.el; // 注入的数据
this.data = config.data; this.renderFn = null
var nodes=document.querySelector(config.el).children;
var i=nodes.length;
if(i>0){
while(i--){
if(nodes[i].tagName.toLowerCase()=="script" && nodes[i].getAttribute("type")=="text/html"){
// 模版id
this.template = nodes[i].innerHTML;
break;
}
}
} this.render()
} // 渲染模版
render(data?): void {
if (data) {
this.data = data;
}
// 解析模版
if(!this.renderFn){
this.renderFn= template.compile(this.template);
} const source = this.renderFn(this.data);
// 更新容器的值
document.querySelector(this.el).innerHTML = source; } setData(value: any): void {
this.data=value;
this.render();
} // 重新设置模板
setTemplate(value: any): void {
this.template = value;
this.renderFn= template.compile(value);
this.render();
} // 获取数据
getData(): object {
return this.data;
} }
编译后的JavaScript
var TemplateList = /** @class */ (function () {
function TemplateList() {
}
return TemplateList;
}());
var TmpBind = /** @class */ (function () {
// 构造函数
function TmpBind(config) {
// 绑定的容器id
this.el = config.el;
// 注入的数据
this.data = config.data;
this.template = new Array();
var nodes = document.querySelector(config.el).children;
TmpBind.getTemplates(nodes, this);
this.render();
}
TmpBind.getTemplates = function (nodes, instance) {
var i = nodes.length;
if (i > 0) {
while (i--) {
if (nodes[i].tagName.toLowerCase() == "script" && nodes[i].getAttribute("type") == "text/html") {
// 模版id
var ts = new TemplateList();
ts.el = nodes[i];
ts.template = nodes[i].innerHTML;
ts.renderFn = template.compile(ts.template);
ts.source = ts.renderFn(instance.data);
ts.els = new Array();
instance.template.push(ts);
}
if (nodes[i].children && nodes[i].children.length > 0) {
TmpBind.getTemplates(nodes[i].children, instance);
}
}
}
};
// 渲染模版
TmpBind.prototype.render = function (data) {
this.reset();
if (data) {
this.data = data;
}
for (var i = 0; i < this.template.length; i++) {
var div1 = document.createElement("div");
this.template[i].source = this.template[i].renderFn(this.data);
div1.innerHTML = this.template[i].source;
this.template[i].els = new Array();
while (div1.childNodes.length > 0) {
this.template[i].els.push(div1.childNodes[0]);
this.template[i].el.parentNode.insertBefore(div1.childNodes[0], this.template[i].el);
}
}
document.querySelector(this.el).template = this.template;
};
// 重置
TmpBind.prototype.reset = function () {
var template = document.querySelector(this.el).template;
if (template) {
for (var i = 0; i < template.length; i++) {
if (template[i].els && template[i].els.length > 0) {
var j = template[i].els.length;
while (j--) {
template[i].els[j].parentNode.removeChild(template[i].els[j]);
}
}
}
}
};
// 设置数据
TmpBind.prototype.setData = function (value) {
this.data = value;
this.render();
};
// 获取数据
TmpBind.prototype.getData = function () {
return this.data;
};
return TmpBind;
}());
示例:
<div id="div2">
这是第一个模版......
<script type="text/html">
<p>{{msg}}</p>
<ul>
{{each list as item}}
<li>{{item}}</li>
{{/each}}
</ul>
</script>
二个模版
<script type="text/html"> <ul>
{{each list as item}}
<li>{{item}}</li>
{{/each}}
</ul>
</script>
N个模版
<script type="text/html"> <ul>
{{each list as item}}
<li>{{item}}</li>
{{/each}}
</ul>
</script>
</div>
<script>
var vm = new TmpBind({
el: "#div2",
data: {
msg: "欢迎来到模版绑定的世界",
list: [1, 2, 3, 4, 5, 6, 7, 8, 9]
}
})
// 获取数据
var data = vm.getData();
// 更改数据
data.msg = "欢迎来到模版绑定的世界3333333333"
data.list.push(333) setTimeout(function () {
// 设置数据
vm.setData(data)
}, 3000) </script>
如果这篇文章对您有帮助,您可以打赏我
技术交流QQ群:15129679
利用art.template模仿VUE 一次渲染多个模版的更多相关文章
- 利用art.template模仿VUE
首先先看一下Typescript代码: import template = require('art-template/lib/template-web'); interface TemplateBi ...
- 利用 vue-cli 构建一个 Vue 项目
一.项目初始构建 现在如果要构建一个 Vue 的项目,最方便的方式,莫过于使用官方的 vue-cli . 首先,咱们先来全局安装 vue-cli ,打开命令行工具,输入以下命令: $ npm inst ...
- vue + element 动态渲染、移除表单并添加验证
博客地址:https://ainyi.com/66 又接到新需求了吧~~ 背景 在一个大表单里,有可能会出现这种需求,用户可以自己操作动态添加.移除表单,更加个性化的效果. 常见于填写个人信息.附加内 ...
- Vue(服务端渲染)
一.前言 1.服务端渲染图解 2.简介服务端渲染 ...
- vue服务端渲染添加缓存
缓存 虽然 Vue 的服务器端渲染(SSR)相当快速,但是由于创建组件实例和虚拟 DOM 节点的开销,无法与纯基于字符串拼接(pure string-based)的模板的性能相当.在 SSR 性能至关 ...
- [vue] vue服务端渲染nuxt.js
初始化 使用脚手架工具 create-nuxt-app 快速创建 npx create-nuxt-app <项目名> npx create-nuxt-app 执行一些选择 在集成的服务器端 ...
- webpack4+koa2+vue 实现服务器端渲染(详解)
_ 阅读目录 一:什么是服务器端渲染?什么是客户端渲染?他们的优缺点? 二:了解 vue-server-renderer 的作用及基本语法. 三:与服务器集成 四:服务器渲染搭建 4.1 为每个请求创 ...
- vue服务端渲染之nuxtjs
前言 本篇主要针对nuxtjs中的一些重要概念整理和代码实现! 在学习vue服务端渲染之前,先搞清楚几个概念: 什么是客户端渲染(CSR) 什么是服务端渲染(SSR) CSR和SSR有什么异同 客户端 ...
- art template前端模板引擎
偶然看到后台有一段代码 采用的是art template的模板引擎 地址为 http://aui.github.io/artTemplate/ 这段代码很简洁 var html = template( ...
随机推荐
- 得到List<HashTable>里面的list然后取list的某一项
//得到List<HashTable>里面的listUnFix然后取listUnFix判断tempfix里面得值 List<Hashtable> list = new List ...
- emqx配置ssl
1.生产自签证书 mkdir /etc/emqttd/certs/ && cd /etc/emqttd/certs/ openssl genrsa -out ca-key.pem 20 ...
- 19,flask消息闪现-flash
Flash消息 请求完成后给用户的提醒消息,flask的核心特性, flash函数实现效果 视图函数中调用flash()方法 html中要使用get_flashed_messages() 后端代码: ...
- httpd的压力测试工具-ab工具使用案例
httpd的压力测试工具-ab工具使用案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.httpd自带的工具程序 事实上,在我们安装完Apache之后,它默认就会给我们安 ...
- MSP430 LaunchPad开发板入门教程集合
MSP-EXP430G2开发板是德州仪器提供的开发工具,也称为LaunchPad,用于学习和练习如何使用其微控制器产品.该开发板属于MSP430 Value Line系列,我们可以对所有MSP430系 ...
- Educational Codeforces Round 64 (Rated for Div. 2)题解
Educational Codeforces Round 64 (Rated for Div. 2)题解 题目链接 A. Inscribed Figures 水题,但是坑了很多人.需要注意以下就是正方 ...
- Hibernate的悲观锁和乐观锁
前一篇博客我们从数据库角度分析,锁可以分为三种,分别为共享锁,独占锁和更新锁.我们从程序的角度来看锁可以分为两种类型,悲观锁和乐观锁,Hibernate提供对这两种锁 的支持,我们来了解一下Hiber ...
- Spark 基础 —— 创建 DataFrame 的三种方式
1.自定义 schema(Rdd[Row] => DataSet[Row]) import org.apache.spark.sql.types._ val peopleRDD = spark. ...
- linux sed 批量替换文件中的字符串或符号
sed -i :直接修改读取的文件内容,而不是输出到终端. sed -i 就是直接对文本文件进行操作的 替换每行第一次出现的字符串 sed -i 's/查找的字符串/替换的字符串/' 文件 ...
- 如何有效使用Project(2)——进度计划的执行与监控
继上次的的<编制进度计划.保存基准>继续讲解如何对计划进行执行和监控. 计划执行即:反馈实际进度.反馈工作消耗(本文只考虑工时,不考虑成本).提出计划变更请求.如果你的企业实施了专门的PM ...