简单封装template.js

1.先来一个例子:

< script type= "text/html" id= "template" >
< ul >
< li >{{name}} </ li >
< li >{{skill}} </ li >
</ ul >
</ script >
< script >
var data = {
name: 'jack',
skill: 'jump'
}
var templateDom = document. getElementById( 'template');
var string = templateDom. innerHTML;
var reg = /{{(\w+ )}}/;
var result = reg. exec( string);
while ( result) {
string = string. replace( result[ 0], data[ result[ 1]]);
result = reg. exec( string);
}
document. body. innerHTML = string;
< / script >
结果:

  • jack
  • jump
2.进行函数封装:

function template( id, data) {
var templateDom = document. getElementById( id);
var string = templateDom. innerHTML;
var reg = /{{(\w+ )}}/;
var result = reg. exec( string);
while ( result) {
string = string. replace( result[ 0], data[ result[ 1]]);
result = reg. exec( string);
}
return string;
}
进行调用一下:

document. body. innerHTML = template( 'template', {
name: 'rose',
skill: 'beautiful'
});
结果:

  • rose
  • beautiful
3.注意事项:

< script type= "text/html" id= "template" >
< ul >
< li >{{name}} </ li >
< li >{{skill}} </ li >
</ ul >
</ script >
a.上面{{}}里面的内容要根据data的key来设置;

b.type只要不为text/javascript,html可以换成其他的名字,如test,但设置为html,编辑器可实现代码自动提示以及高亮的效果;

c.必须给定一个id(id具有唯一性),调用函数时通过id获取对应作用元素.

var reg = /{{(\w+ )}}/;
var result = reg. exec( string);
console. log( result);
d.打印出来的result注意理解(正则表达式exec方法);

4.大神做的template可见:https://aui.github.io/art-template/docs/


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值