利用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( ...
随机推荐
- 【DATAGUARD】物理dg的switchover切换(五)
[DATAGUARD]物理dg的switchover切换(五) 一.1 BLOG文档结构图 一.2 前言部分 一.2.1 导读 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其 ...
- JQuery中两个ul标签的li互相移动
实例 <html > <head> <meta http-equiv="Content-Type" content="text/html; ...
- MySQL/MariaDB数据库的复制监控和维护
MySQL/MariaDB数据库的复制监控和维护 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.清理日志 1>.删除指定日志文件名称之前的日志(也可用基于时间) M ...
- Kali下的内网劫持(二)
前一小节说到在Kali下可以进行捕获客户端的图片,那么同样的,客户端访问的网页也是可以捕获的: . 以上可以看出监听完毕,那么在被监听端访问阿里云的一个网站: 在监听端用urlsnart这个工具进行捕 ...
- sqliteman install parameter
.安装前准备 系统要求:linux Qt库版本:一般都有 .安装文件 官网自行下载 .安装 )这里用的pscp pscp .\sqliteman-.tar.gz root@192.168.30.140 ...
- 解决windows下合上、掀开笔记本盖子后屏幕黑屏的问题
我在macbook上安装了windows10,但是由于驱动问题,虽然我设置的是关闭盖子仅息屏,但是在关闭盖子后一段时间,再掀开,屏幕就怎么样都唤不醒了. 我找到一个方法,虽然治标不治本,但是起码能解决 ...
- Tarjan算法分解强连通分量(附详细参考文章)
Tarjan算法分解强连通分量 算法思路: 算法通过dfs遍历整个连通分量,并在遍历过程中给每个点打上两个记号:一个是时间戳,即首次访问到节点i的时刻,另一个是节点u的某一个祖先被访问的最早时刻. 时 ...
- 大数据JavaWeb之java基础巩固----Junit&反射&注解
最近打算从0开始学学大数据,目前的主业是Android开发,但是当年毕业之后其实是搞J2EE的,所以打算没事又来拓展一下后台的技能,扩宽一下自己的知识体系对于自己的未来也能够多一些可能,另外大数据的一 ...
- python测试开发django-rest-framework-61.权限认证(permission)
前言 用户登录后,才有操作当前用户的权限,不能操作其它人的用户,这就是需要用到权限认证,要不然你登录自己的用户,去操作别人用户的相关数据,就很危险了. authentication是身份认证,判断当前 ...
- discuz x3.4 开启tags聚合标签及伪静态配置方法
因为SEO的需要,要做tags聚合到一个页面,做到伪静态. 例如: misc.php?mod=tag >>> /tag/ misc.php?mod=tag&id=47 > ...