概述
我们在使用JS渲染DOM时,一般使用字符串创建DOM然后附加到父元素上,如果附加的DOM是动态易变的,那需要在函数中写大量逻辑。如果在控件实现过程中,这带来的问题更为严重。
解决这个问题的常见解决方案是是使用模板,作为配置项传入控件,实现数据和渲染的分离。具体的实现方法有以下方法:
- 字符串替换,使用正则匹配将数据替换进字符串中。
- 渲染函数,函数返回字符串。
- 模板引擎,可以将执行字符串中的函数(内置或者自定义的)
替换(Substitute)
字符串替换是最简单的实现模板的方式,看一下具体的实现:
1. 定义替换函数
复制代码 代码如下:
/**
* 替换字符串中的字段.
* @param {String} str 模版字符串
* @param {Object} o json data
* @param {RegExp} [regexp] 匹配字符串的正则表达式
*/
function substitute(str,o,regexp){
return str.replace(regexp || /\\?\{([^{}]+)\}/g, function (match, name) {
return (o[name] === undefined) ? '' : o[name];
});
}
2.使用配置项:
复制代码 代码如下:
var config = {
data : {value : '123',text:'abc'},
template : '<label>{text}</label><input type="text" value="{value}"/>'
};
3. 在创建DOM的过程中我们这样调用:
复制代码 代码如下:
var str = substitute(template,data);
$(str).appendTo('body');
通过以上示例,我们就完成了数据和字符串的解耦,可以灵活的用在控件中,当前大多数JS框架都提供了此种方式的模板。
在此基础上可以有下面的扩展,感兴趣的可以自己去实现:
1. 使用数字代替参数名:
如 '<label>{0}</label><input type="text" value="{1}"/>'
2. 嵌套使用对象属性:
如 '<label>{obj.name}</label><input type="text" value="{obj.value}"/>'
优点:实现简单,易于理解。
缺点:只能进行简单的数据结构,无法处理循环、条件语句。
渲染方法(Render)
我们可以在渲染函数中处理非常复杂的逻辑,可以将渲染函数作为参数传入配置项。
配置项:
复制代码 代码如下:
var config = {
data : [{value : '0',text:'abc'},{value : '1',text:'bcd'}],
renderer : function(obj){
if(obj.value === '0'){
return obj.text;
}else{
return '<img title="' + obj.text + '" src="/UploadFiles/2021-04-02/">
}
}
};
在使用时:
复制代码 代码如下:
for(var i = 0 ; i< data.length; i++){
var obj = data[i],
str = config.renderer(obj);
$(str).appendTo('body');
}
在处理循环,条件语句时,这是一种很好的解决方案。
优点:实现相对简单,实现灵活,能满足复杂数据结构,易于调试
缺点:
- 渲染函数作为配置项,不易理解。
- 函数较长时,使配置项臃肿。
- 每个场景都需要自己实现渲染函数。
模板引擎(XTemplate)
每一个JS UI库都会有一个功能强大的模板引擎,一个模板引擎需要实现以下功能:
1. 字符串替换
2. 处理复杂语句 条件、循环
3. 使用内嵌函数
4. 允许用户传入自定义函数
目前的模板引擎有2种常见的实现方式:
1. 使用正则分析字符串,执行其中的特殊语句逻辑,替换对应的数据
我们来看一下KISSY 模板的一个实例:
'Hello, {{#each users}}{{#if _ks_value.show}}{{_ks_value.name}}{{/if}}{{/each}}.'
上面这是一个模板,可以处理循环、条件语句。
2. 对字符串进行语法分析,生成语法树,执行替换对应的标签或数据。
下面是Ext的 xtemplate使用方式:
复制代码 代码如下:
var tpl = new Ext.XTemplate(
'<p>{name}\'s favorite beverages:</p>',
'<tpl for="drinks">',
'<div> - {.}</div>',
'</tpl>'
);
tpl.overwrite(panel.body, data);
优点:功能强大,灵活性高
缺点:使用复杂,更加不易理解。不便于调试。
问题思考
1. 控件中使用模板,可以将数据和DOM分离,但是如果一个控件中包含大量的模板,会增加使用者的工作量,而且不易于调试,需要权衡使用。
2. 如果大量控件使用相同的模板,和相同的数据结构,每个控件单独配置不便于使用,更好的方案是允许父控件配置模板。
JS模板,实现方法
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 【雨果唱片】中国管弦乐《鹿回头》WAV
- APM亚流新世代《一起冒险》[FLAC/分轨][106.77MB]
- 崔健《飞狗》律冻文化[WAV+CUE][1.1G]
- 罗志祥《舞状元 (Explicit)》[320K/MP3][66.77MB]
- 尤雅.1997-幽雅精粹2CD【南方】【WAV+CUE】
- 张惠妹.2007-STAR(引进版)【EMI百代】【WAV+CUE】
- 群星.2008-LOVE情歌集VOL.8【正东】【WAV+CUE】
- 罗志祥《舞状元 (Explicit)》[FLAC/分轨][360.76MB]
- Tank《我不伟大,至少我能改变我。》[320K/MP3][160.41MB]
- Tank《我不伟大,至少我能改变我。》[FLAC/分轨][236.89MB]
- CD圣经推荐-夏韶声《谙2》SACD-ISO
- 钟镇涛-《百分百钟镇涛》首批限量版SACD-ISO
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】