doT js 常见错误

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

Html代码  doT js 常见错误
  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>  

 
doT js 常见错误
 
但是我不太喜欢放在script标签中,我喜欢把模板放在div中,如下:

Html代码  doT js 常见错误
  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>  

 但是下面的代码就出现了问题:
doT js 常见错误
 

报错信息如下:
doT js 常见错误
 
这是为什么呢?因为js在获取div的内容时,自动把div中的内容进行了转义:

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

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

 

Js代码  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代码  doT js 常见错误
  1. var evalText = doT.template(htmlDecode($invoiceListDot.html()));  
  2.                     $invoiceListDiv.html(evalText(invoiceInfoDtos));  

 

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

上一篇:阿里云服务器ECS与传统服务器、虚拟主机、VPS主机有何区别?


下一篇:Coursera Machine Leaning 课程总结