Underscore解析html模板

Underscore 的_.template模板函数只能解析3种模板标签

<%  %>:用于包含Js代码,这些代码将在渲染数据时被执行。

<%= %>:用于输出数据,可以是一个变量、对象的属性、或函数(输出函数的返回值)。

<%- %>:用于输出数据,同时会将数据中包含的HTML字符转换为实体形式(例如它会将双引号转换为&quot;形式),用于避免XSS攻击。

当我们希望将数据中的HTML作为文本显示出来时,可以使用<%- %>标签。

Underscore还允许你修改这3种标签的形式,如果我们想使用{% %}、{%= %}、{%- %}作为标签,可以通过修改templateSettings来实现

_.templateSettings = {      
    evaluate : /\{%([\s\S]+?)\%\}/g,      
    interpolate : /\{%=([\s\S]+?)\%\}/g,     
    escape : /\{%-([\s\S]+?)%\}/g  
}

此方法还可以用于解决和其它模板语言的标签冲突

示例:

模板:

<script type="text/template" id="tpl">
   <div>{%=say%}</div>
</script>

调用代码

var data = {};
data.say = "Hello World!";
$("body").html(_.template($("#tpl").html(),data));









转载于:https://my.oschina.net/cangy/blog/346970

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值