doT js 常见错误

简介:

doT 模板一般是放在script脚本里面的,例如:

Html代码   收藏代码
  1. <!DOCTYPE html>  
  2. <html lang="en">  
  3. <head>  
  4.     <meta charset="UTF-8">  
  5.     <title></title>  
  6.     <script type="text/javascript" src="../../doT.js"></script>  
  7.     <script type="text/javascript" src="http://hbjltv.com/static/js/jquery-1.11.1.js"></script>  
  8. </head>  
  9. <body>  
  10. <script id="conditionstmpl">  
  11.     {{ if(!it.name){ }}  
  12.     <div> 你还没有名字</div>  
  13.     {{ } else { }}  
  14.     <div>Oh, I love your name, {{=it.name}}!</div>  
  15.     {{ }  }}  
  16. </script>  
  17. <hr/>  
  18. <div id="condition"></div>  
  19. <script type="text/javascript">  
  20.     var dataEncode = {"name": "", "age": 31};  
  21.     var interText = doT.template($("#conditionstmpl").text());  
  22.     $("#condition").html(interText(dataEncode));  
  23. </script>  
  24. </body>  
  25. </html>  

 

 
但是我不太喜欢放在script标签中,我喜欢把模板放在div中,如下:

Html代码   收藏代码
  1. <body>  
  2. <div id="conditionstmpl">  
  3.     {{? it.name }}  
  4.     <div>Oh, I love your name, {{=it.name}}!</div>  
  5.     {{?? !it.age == 0}}  
  6.     <div>Your age is {{=it.age}}</div>  
  7.     {{??}}  
  8.     You don't have age and still don't have a name?  
  9.     {{?}}  
  10. </div>  
  11. <hr/>  
  12. <div id="condition"></div>  
  13. <script type="text/javascript">  
  14.     var dataEncode ={"name":"","age":0};  
  15.     var interText = doT.template($("#conditionstmpl").html());  
  16.     $("#condition").html(interText(dataEncode));  
  17. </script>  
  18. </body>  

 但是下面的代码就出现了问题:

 

报错信息如下:

 
这是为什么呢?因为js在获取div的内容时,自动把div中的内容进行了转义:

转义前 转义后
< &lt ;
> &gt ;

即把小于号变成了&lt ; ,这不是我预期的.因为html把<转化成了&lt ;,所以doT 报错了. 
解决方法:使用如下方法还原

 

Js代码   收藏代码
  1. /*** 
  2.  * Html解码获取Html实体<br> 
  3.  *     '&lt;'--> '<' 
  4.  * @param value 
  5.  * @returns {*|jQuery} 
  6.  */  
  7. function htmlDecode(value){  
  8.     return $('<div/>').html(value).text();  
  9. }  

 处理模板的js:

Js代码   收藏代码
  1. var evalText = doT.template(htmlDecode($invoiceListDot.html()));  
  2.                     $invoiceListDiv.html(evalText(invoiceInfoDtos));  

 

参考:http://blog.csdn.net/hw1287789687/article/details/46671437

相关文章
|
JavaScript 前端开发
|
前端开发 JavaScript
|
JavaScript
doT js模板入门 3
<div class="markdown_views"> <p><strong>for 循环前判断循环的list是否为空</strong></p> <pre class="prettyprint"><code class=" hljs handlebars"><span class="xml"><span class="hljs-tag">&lt;<span class="h
1403 0
|
JavaScript 前端开发 Java
doT js模板入门 2
<div class="markdown_views"> <p>doT js 使用{{}} 非常类似于JSP,所以用起来感觉很亲切,很顺手 <br><strong>{{</strong>–&gt;<strong>&lt;%</strong> <br><strong>}}</strong>–&gt;<strong>%&gt;</strong> <br> 例如:</p> <pre
1214 0
|
JavaScript 前端开发
doT js模板入门
<div class="markdown_views"> <p>doT.js github地址: <br><a href="http://olado.github.io/doT/">doT.js 官方网站 </a> <br><strong><em>实例1:简单</em></strong></p> <pre class="prettyprint"><code class="
2314 0
|
2月前
|
JavaScript 前端开发
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
43 1
JavaScript中的原型 保姆级文章一文搞懂
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
127 2
|
2月前
JS+CSS3文章内容背景黑白切换源码
JS+CSS3文章内容背景黑白切换源码是一款基于JS+CSS3制作的简单网页文章文字内容背景颜色黑白切换效果。
27 0
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
180 4

热门文章

最新文章