underscore.js预编译模板使用

LMn*_*net 7 template-engine precompile underscore.js underscore.js-templating

我想使用预编译的underscore.js模板.我使用_.template().source并保存结果文件.但我不明白,如何使用这个模板.预编译模板是字符串,我无法将其强制转换为函数.我尝试使用eval,但它总是返回解析错误.

例如:

<div>
    <% for(var i = 0; i < 5; i++){ %>
        <div><%=i%></div>
    <% } %>
</div>
Run Code Online (Sandbox Code Playgroud)

标准使用:

_.template(tpl).({});
Run Code Online (Sandbox Code Playgroud)

结果:

<div>

    <div>0</div>

    <div>1</div>

    <div>2</div>

    <div>3</div>

    <div>4</div>

</div>
Run Code Online (Sandbox Code Playgroud)

预编译:

_.template(tpl).source
Run Code Online (Sandbox Code Playgroud)

预编译模板:

"function(obj){
var __t,__p='',__j=Array.prototype.join,print=function(){__p+=__j.call(arguments,'');};
with(obj||{}){
__p+='<div>\n\t';
 for(var i = 0; i < 5; i++){ 
__p+='\n\t\t<div>'+
((__t=(i))==null?'':__t)+
'</div>\n\t';
 } 
__p+='\n</div>\n';
}
return __p;
}"
Run Code Online (Sandbox Code Playgroud)

运行预编译模板:

var a = eval(tplc);
a({});
Run Code Online (Sandbox Code Playgroud)

错误:

Error
line: 1
message: "Parse error"
sourceId: 139746789246216
__proto__: SyntaxError
Run Code Online (Sandbox Code Playgroud)

LMn*_*net -2

我终于找到了这个解决方案。我不能说这是一个优雅的解决方案,但它确实有效。以我为例:

var a = eval('[' + tplc + ']')[0];
a({});
Run Code Online (Sandbox Code Playgroud)