如下标签: 复制代码代码如下: {dede:list pagesize=’6′} <li><a href="/plus/jobs.php?lang={dede:global.user_lang/}&jobid=[field:id/]">[field:jobname/]</a></li> {/dede:list} 当运行的时候,发现{dede:global.user_lang/}居然原封不动的被展示了出来而未被解析,我很纳闷,于是去网上搜了有关DEDECMS不能嵌套标签的解决办法,最后找出了两种解决方案。
方案一: 复制代码代码如下: <!–在标签之前,先用JS获取标签中需要得到的内容–> <script type="text/javascript"> function get_user_lang(){ document.write("{dede:global.user_lang/}"); } </script> {dede:list pagesize=’6′} <!–然后在标签中调用该JS函数把内容给显示出来–> <li><a href="/plus/jobs.php?lang=<script type="text/javascript">get_user_lang();</script>&jobid=[field:id/]">[field:jobname/]</a></li> {/dede:list} 显然,这种办法肯定不是我要的,因为该方法不仅复杂,而且不容易维护,更重要的是与我尽量的坚持行为和结构分离的习惯相悖,于是又在网上搜了搜,结果发现了更加方便的解决办法,即把{dede:global.user_lang/}更改成[field:global.user_lang/]。
方案二: 复制代码代码如下: {dede:list pagesize=’6′} <li><a href="/plus/jobs.php?lang=[field:global.user_lang/]&jobid=[field:id/]">[field:jobname/]</a></li> {/dede:list} 是不是很简单呢,该方法不仅简单,而且容易维护,也符合结构和行为分离的良好习惯,当然,适用其他标签或者在DEDECMS中也是适用的。