利用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( ...
随机推荐
- 使用opencv去操作树莓派摄像头保存图片和视频
利用树莓派的摄像头去学习opencv的基本操作 —— 保存图片和视频 1.使用Opencv去控制树莓派的摄像头拍照并保存到本地,主要使用cv2和numpy库 #!/usr/bin/python3 # ...
- Pyspark中遇到的 java.io.IOException: Not a file 和 pyspark.sql.utils.AnalysisException: 'Table or view not found
最近执行pyspark时,直接读取hive里面的数据,经常遇到几个问题: 1. java.io.IOException: Not a file —— 然而事实上文件是存在的,是 hdfs 的默认路径 ...
- 数据库开发-Django ORM的一对多查询
数据库开发-Django ORM的一对多查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.联合主键问题 CREATE TABLE `employees` ( `emp_no` ...
- Jenkins - 扯淡篇
目录 什么是持续集成 持续集成的概念 持续交付 持续部署 流程 当没有Jenkins的时候... 什么是Jenkins 返回Jenkins目录 什么是持续集成 由于懒得写,所以本段摘自阮一峰老师的博客 ...
- js插件---videojs的使用
js插件---videojs的使用 一.总结 一句话总结: 网上有各种细致的现成的代码可以拿来用,没必要自己死专 1.video.js有两种初始化方式? 一种是在video的html标签之中 一种是使 ...
- Spring Boot-初学01 -使用Spring Initializer快速创建Spring Boot项目 -@RestController+spEL -实现简单SpringBoot的Web页面
1.IDEA:使用 Spring Initializer快速创建项目 IDE都支持使用Spring的项目创建向导快速创建一个Spring Boot项目: 选择我们需要的模块:向导会联网创建Spring ...
- P5024 保卫王国[倍增+dp]
窝当然不会ddp啦,要写这题当然是考虑优化裸dp啦,但是这题非常麻烦,于是变成了黑题. 首先,这个是没有上司的舞会模型,求图的带权最大独立集. 不考虑国王的限制条件,有 \[ dp[x][0]+=dp ...
- datebox设置默认时间
1. html代码: <input id="txtBeginTime" class="easyui-datebox" data-options=" ...
- 项目Alpha冲刺——集合
作业描述 课程: 软件工程1916|W(福州大学) 作业要求: 项目Alpha冲刺(团队) 团队名称: 火鸡堂 作业目标: 完成项目Alpha冲刺 团队信息 队名:火鸡堂 队员学号 队员姓名 博客地址 ...
- 如何使用keil5将stm32的hal库编译成lib文件——F1版本
hal库中keil5中编译的速度是比较慢的,相同情况下,每次都要编译的时候,比标准库是要慢很多的,因此就hal库编译成lib文件是一种加快编译速度的方法,当然也有其自身的缺点.一.步骤1.使用cube ...