dedecms产品栏目调取子栏目错乱的解决方法

dedecms源码程序在php空间里面已经运行了一年多了,但是朋友在后台自己更新文章的时候,突然发现栏目错乱,这个的意思是什么呢?比如说xxx栏目下没有子栏目,而这个栏目确出现了其他的子栏目。接下来把这个问题就给讨论一下。 首先我们查看一下这位朋友产品栏目调用的代码:

{dede:channelArtlist typeid='3' } <li> {dede:type} <a style='font-size:14px;color:#D1D8E3;' href="[field:typelink%20/]"><b>[field:typename /]</b></a> {/dede:type}</li> {dede:channel type='son' noself='yes'} <li>  <a style='font-size:12px;color:#FF9224;' href='[field:typelink%20/]'>[field:typename/]</a></li> {/dede:channel} {/dede:channelArtlist}

从这样的看上去其实并没有多大的问题,但是更新出来的就不一样了。这里的解决方法就是把子栏目的{dede:channel}标签换成{dede:sql}标签来代替使用。这个要怎么使用呢?

{dede:sql sql='Select * from dede_arctype where reid=~id~ and ishidden != 1 ORDER BY id limit 0,20'}

然后结尾 {/dede:sql} 其中还需要把 href='[field:typelink /]’ 更换为: href=”[field:typedir function=’str_replace(“{cmspath}”,””,@me)’/]” 这样就完美的解决了

修改后代码为:

{dede:channelArtlist typeid='3' } <li> {dede:type} <a style='font-size:14px;color:#D1D8E3;' href="[field:typelink%20/]"><b>[field:typename /]</b></a> {/dede:type} </li> {dede:sql sql='Select * from dede_arctype where reid=~id~ and ishidden != 1 ORDER BY id limit 0,20'} <li>   <a style='font-size:12px;color:#FF9224;' href="[field:typedir%20function='str_replace("{cmspath}","",@me)'/]"> [field:typename/] </a> </li> {/dede:sql} {/dede:channelArtlist}

这里需要注意到的是要把这个sql语句中dede_arctype中的前缀dede修改为您的表前缀,表前缀根据自己网站的表前缀进行修改。

注明:本文为星速云原创版权所有,禁止转载,一经发现将追究版权责任!

(0)
上一篇 2022年8月4日 下午12:38
下一篇 2022年8月4日 下午12:38

相关推荐

发表评论

登录后才能评论
问答社区 QQ客服
微信客服
微信客服
分享本页
返回顶部