织梦channelartlist有二级栏目实现一级栏目高亮的解决方法

2017-06-26 dedecms
织梦栏目如果有二级栏目默认无法进行高亮显示,需要进行一下简单修改,具体方法如下:
打开文件include\taglib\channelartlist.lib.php
找到:
 
$pv->Fields['typeurl'] = GetOneTypeUrlA($typeids[$i]);


在此行代码下方增加以下代码:

if($typeids[$i]['id'] == $refObj->TypeLink->TypeInfos['id'] || $typeids[$i]['id'] == $refObj->TypeLink->TypeInfos['topid'] ){
            $pv->Fields['currentstyle'] = $currentstyle ? $currentstyle : 'current';
        }
        else{
            $pv->Fields['currentstyle'] = '';
        }

如下图:



添加这个后才能对二级栏目也起作用
调用方法:
 
{dede:channelartlist typeid='2' currentstyle='active'}
<li class='{dede:field.currentstyle/}'><a href='{dede:field name='typeurl'/}'>{dede:field name='typename'/}</a></li>
。。。
{/dede:channelartlist}

 
完整有二级栏目调用方法案例:

<ul class="clearfix">
	<li class="active">
		<a title="" href="/">首页</a>
	</li>	
	 {dede:channelartlist row='4' typeid='top' currentstyle='active' }
	<li class='{dede:field.currentstyle/}'>
		<a class="dy-navlist" title="{dede:field name='typename'/}" href='{dede:field name='typeurl'/}' >
			{dede:field name='typename'/}
		</a>
		<ol>
		{dede:channel type='son' noself='yes' }
		<li><a href='[field:typelink/]'>[field:typename/]</a></li>
		{/dede:channel}
		</ol>
	</li>
	{/dede:channelartlist}
</ul>


如果是当前栏目则 li的class属性显示active,否则显示class='' ,也可以修改currentstyle='这里改为你需要的类名'。

-------------------------------------------------------------------------------------------------------------------------
也可以与arclist标签相结合使用,
这样调用:

{dede:channelartlist typeid='2' currentstyle='current'}
<dt ><a class='{dede:field.currentstyle/}' href='{dede:fieldname='typeurl'/}'>{dede:field name='typename'/}</a></dt>
{dede:arclist titlelen='42' row='10' currentstyle="<dd><a class='current' href='~typelink~'>~typename~</a></dd>"}
     [field:array runphp='yes']
         if(@me['currentstyle']){
             @me = @me['currentstyle'];
         }else{
             @me = "<dd ><a href='{@me['arcurl']}'>{@me['title']}</a></dd>";
         }
     [/field:array]
{/dede:arclist}
{/dede:channelartlist}

希望这篇文章对大家有所帮助。