加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
js-template.js 1.99 KB
一键复制 编辑 原始数据 按行查看 历史
tom.han.imaginato 提交于 2013-09-29 16:42 . improve js template
/*****
模板字符串,语法标签采用<js></js>
完全遵循javascript原生语法,内置输出函数为echo(string);函数
常用调用例子,可以用 如果下方法.
<textarea id="template_code" style="display:none'>
<js> for(var i=0;i<names.length;++i){</js>
<label><h1><js> echo(names[i]);</js></h1></label>
<js> }</js>
</textarea>
js_template(document.getElementById('template_code').value,{names:['tom','jerry','david']});
异常处理:
eval解析异常会往window.AJ变量里面记录debug信息方便调试。
作者:浮山狼
邮箱:fushanlang@gmail.com
若使用中遇到问题,欢迎交流、切磋!
*/
function js_template(template, values) {
//模板输出结果
var result = "";
//公共的输出函数
var echo = function (output) {
result += output;
}
//记录解析错误
var errors=window.AJ;
window.AJ=errors=!errors?[]:errors;
//唯一分隔标志字符串
var split = '_{' + Math.random() + '}_';
//消除换行符
var estr = template.replace(/\n|\r|\t/g, "");
var js = [];
/****
* 匹配标签<js> ...</js>--并且替换为特定的分隔串,
* 并将匹配的js代码放入js数组中备用
* */
estr = estr.replace(/<js>(.*?)<\/js>/g, function ($0, $1) {
js.push($1);
return split;
});
/*根据特定的分隔串分隔得到普通txt文本串的数组*/
var txt = estr.split(split);
estr = "";
/****
* 0101010---0为txt[]元素,1为js[]元素
* 重新串起来连接为可执行eval的estr
* **/
for (var i = 0; i < js.length; ++i) {
estr += 'echo(txt[' + i + ']);';
estr += js[i];
}
estr += 'echo(txt[' + js.length + ']);';
try {
if (values) {
for (var i in values) {
eval('var ' + i + ' =values[i];');
}
}
eval(estr);
}
catch (error) {
errors.push([error,estr,template]);
} finally {
return result;
}
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化