网页特效代码_站长素材站移动版

DeDecms教程

主页 > CMS教程 > DeDecms教程 >

dede织梦调用顶级二级栏目及下三级栏目方法(数据库实现)

  • ①:通过dede调用二级栏目大家都会调用,但要调用三级栏目,就有点麻烦了,如下样式的三级栏目dede如何调用呢?如下:
  • ----------------------------------------A级主栏目
                   +顶级栏目
                        +二级栏目
                             +三级栏目(A)
                             +三级栏目(B)
                             +三级栏目(C)
                         +二级栏目
                             +三级栏目(D)
                             +三级栏目(E)
                             +三级栏目(F)
    ----------------------------------------B级主栏目     
                   +顶级栏目
                        +二级栏目(G)
                        +二级栏目(H)
                        +二级栏目(I)

    {dede:channelartlist typeid=6 row=4} (注:这是顶级栏目id)
    <div class="cpmll">
    <span><a href="{dede:field name='typeurl'/}">{dede:field name='typename'/}</a></span> (注:这是二级栏目名称)
    <ul>
    {dede:sql sql='Select * from dede_arctype where reid=~id~  ORDER BY id limit 0,7'}
    <li><a href='[field:typedir function='str_replace("{cmspath}","",@me)'/]' target='_blank'>[field:typename/]</a></li>(注:这是三级栏目的静态路径和栏目名称)
    {/dede:sql}
    </ul>
    </div>
    {/dede:channelartlist}
  •  因为[field:typedir /]在数据库存储的路径包括{cmspath}这个字符串,所以我们必须处理一下,就用到织梦(dedecms)自带的cn_substr这个系统函数,这里简要说一下这个函数的参数,@me是当前字段值,也就是取出的[field:typedir /]这个值,200和9表示从第9个字符位置( (不包括这个字符))开始截取200个字符。
    typeid='' 指定顶级栏目就可以啦, limit0,7 这个7是控制三级栏目的显示个数的,显示样式自己调整CSS。

  • ②:可能有很多人因为各种需要,不论是增加密度还是操作方面的便捷性增强用户体验,会涉及到dede需要增加三级或者更深层级导航的需求,咱和尚废话不多说了,直接上代码:

    <ul>
     <li>{dede:type typeid='3'}<a href="[field:typelink/]">[field:typename/]{/dede:type}</a> (如果上面二级名称掉不出来可以用这个)
       <ul>
        {dede:channelartlist typeid='3'}
        <li><a href='{dede:field name='typeurl'/}'>{dede:field name='typename'/}</a>
    	 <ul> 
    	 {dede:sql sql='Select * from dede_arctype where reid=~id~'}<li>
    	 <a href='[field:typedir function='str_replace("{cmspath}","",@me)'/]'>[field:typename/]</a></li>     {/dede:sql}
         </ul>
        </li>
    	{/dede:channelartlist}
       </ul>
     </li> 
    </ul>

    以上代码能够实现理论上无限层级深度的导航菜单调用,哈哈,当然,只要你需要,就能满足,显示效果需要CSS来修饰一下。  

(责任编辑:admin)

    468x60