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
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
1356 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
1183 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="
2270 0
|
2月前
|
JavaScript
Node.js【GET/POST请求、http模块、路由、创建客户端、作为中间层、文件系统模块】(二)-全面详解(学习总结---从入门到深化)
Node.js【GET/POST请求、http模块、路由、创建客户端、作为中间层、文件系统模块】(二)-全面详解(学习总结---从入门到深化)
27 0
|
2月前
|
消息中间件 Web App开发 JavaScript
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
75 0
|
8天前
|
JavaScript 前端开发 应用服务中间件
node.js之第一天学习
node.js之第一天学习
|
1月前
|
运维 JavaScript 前端开发
发现了一款宝藏学习项目,包含了Web全栈的知识体系,JS、Vue、React知识就靠它了!
发现了一款宝藏学习项目,包含了Web全栈的知识体系,JS、Vue、React知识就靠它了!
|
1月前
|
JavaScript
Vue.js学习详细课程系列--共32节(4 / 6)
Vue.js学习详细课程系列--共32节(4 / 6)
33 0