日期:2014-05-18  浏览次数:20878 次

freemarker与jquery标志符冲突怎么办?
我们用freemarker做展示层,freemarker语法默认采用<# ></>尖括号形式,为了与html代码清晰分离,freemarker还提供[ ]方括号形式,只需配置一下,我们就是采用[]的形式。
jquery是最优秀的js框架,我们也采用了,jquery中对象选择器也用了方括号,如$("input[@type=checkbox]")表示所有的复选框,于是与freemarker产生了冲突,[@....]会被freemarker执行而报错,请问该如何解决呢?

------解决方案--------------------
jquery里面的$好像可以用jquery代替
有一本jquery基础教程上面有,verycd上面有电子版,可以看看
------解决方案--------------------
将$("input[@type=checkbox]")放到freemarker的注释中,这样freemarker不会解析执行,但JavaScript由于不认识freemarker的注释,依然会执行,假设freemarker的注释符号为/* */

/* 
<script>
$("input[@type=checkbox]")
<script>

*/


------解决方案--------------------
将$("input[@type=checkbox]")放到freemarker的注释中,这样freemarker不会解析执行,但JavaScript由于不认识freemarker的注释,依然会执行,假设freemarker的注释符号为/* */ 

/* 
<script type="text/javascript"> 
$("input[@type=checkbox]") 
</script> 

*/ 

------解决方案--------------------
jquery中使用xpath表达式可以把@省略掉
$("input[type=checkbox]");
这样写一样可以取到值
------解决方案--------------------
取到所有被选中的表单元素
$("input:checked)") 
取到所有没被选中的表单元素
$("input:not(:checked)") 
加起来就差不多了吧~~
------解决方案--------------------
关注中