這篇文章主要介紹了織夢DEDEEIMS標簽不能嵌套的2種解決方法,即dede標簽中嵌套另一個dede標簽時不能正常解析問題的解決方法,需要的朋友可以參考下
如下標簽:
代碼如下:
{dede:list pagesize=’6′}
<li><a href="/plus/jobs.php?lang={dede:global.user_lang/}&jobid=[field:id/]">[field:jobname/]</a></li>
{/dede:list}
當運行的時候,發(fā)現(xiàn){dede:global.user_lang/}居然原封不動的被展示了出來而未被解析,我很納悶,于是去網(wǎng)上搜了有關DEDECMS不能嵌套標簽的解決辦法,最后找出了兩種解決方案。
方案一:
代碼如下:
<!–在標簽之前,先用JS獲取標簽中需要得到的內容–>
<script type="text/javascript">
function get_user_lang(){
document.write("{dede:global.user_lang/}");
}
</script>
{dede:list pagesize=’6′}
<!–然后在標簽中調用該JS函數(shù)把內容給顯示出來–>
<li><a href="/plus/jobs.php?lang=<script type="text/javascript">get_user_lang();</script>&jobid=[field:id/]">[field:jobname/]</a></li>
{/dede:list}
顯然,這種辦法肯定不是我要的,因為該方法不僅復雜,而且不容易維護,更重要的是與我盡量的堅持行為和結構分離的習慣相悖,于是又在網(wǎng)上搜了搜,結果發(fā)現(xiàn)了更加方便的解決辦法,即把{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中也是適用的。