织梦dedecms调用得到文章所属的副栏目id及副栏目名称网址链接等

雪花徐徐飘下,如芦花,似柳絮,像轻悠悠的鹅毛,无尽无休地飘着,飘着,宛如那美丽的银蝶在院中翩翩起舞,又像一群穿白纱裙的小舞女,伴着天空传来的仙乐,轻轻盈盈地在空中飘舞着,旋转着,跳着动人的舞蹈。那么轻快的身影,那么飘逸的舞姿,每一片晶莹的雪花都像一曲婉转、悠扬、清新的轻音乐,都仿佛是一首轻快、和谐、明丽的小诗。哦,神奇的小雪花……

织梦在发表文章时,你会发现有一个副栏目的功能.比如一个文章,他可能即属于你的科技栏目,也属于互联网栏目,那你在发表这个文章时,主栏目可以选择科技,副栏目可以在互联网上打勾选定.

文章的副栏目保存在数据库表archives中的typeid2这个字段中.

效果图.文章属于商会.及德商文化等.三个栏目.我里在栏目显示出来.点击链接后,就会进入相关的栏目中.这里是js函数的形式.只作案例演示.

模板标签代码为view plaincop

{dede:arclist row='2' titlelen='100'typeid=2 orderby='id' }  
        <span>  
        <a  rel="nofollow noopener noreferrer" href="javascript:"onclick="javascript:change_tab([field:typeid/]);">[field:typename/]</a>  
        <!-- 上面是文章所属的主栏目,很方便调用. -->  
        [field:typeid2 function="get_url_by_typeid2(@me)"/]  
        <!-- 上面是文章所属的副栏目,需要单独写函数get_url_by_typeid2 -->  
        </span>  
{/dede:arclist}  

函数代码,需要增加在\include\extend.func.PHP中

//得到副栏目信息,并组织字符串  
function get_url_by_typeid2($typeid2){  
        $arrs=explode(",",$typeid2);//解析副栏目字段  
        if($typeid2==0){  
        return '';  
        }else{  
        $url='';  
        foreach($arrs as $v){  
            $url.='<a rel="nofollow noopener noreferrer" href="javascript:"  
            onclick="javascript:change_tab('.$v.');">'.get_typename($v).'</a>';  
        }  
        return $url;  
        }  
}  
//织梦根据栏目编号typeid调用typename栏目名  
function get_typename($typeid){  
    global $dsql;  
    $rs=$dsql->getOne("select typename from arctype where id='$typeid'");  
return $rs['typename'];  
}  
ew plaincopy 另外特别注意,织梦标签artlist不能调用副栏目中的文章内容的问题,即文章属于互联网这个副栏目,但互联网栏目中却不显示这个文章.

需要修改系统文件./include/taglib/arclist.lib.php

295到296行修改

原代码view plaincopy

if($CrossID=='') $orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).')';  
else $orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).','.$CrossID.')';  
修改为
if($CrossID=='')  
$orwheres[] = " (arc.typeid in (".GetSonIds($typeid).") or arc.typeid2 in (".GetSonIds($typeid).") or CONCAT( ',', arc.typeid2, ',' ) LIKE '%,".$typeid.",%' )";  
else  
$orwheres[] = " (arc.typeid in (".GetSonIds($typeid).",".$CrossID.") or arc.typeid2 in (".GetSonIds($typeid).",".$CrossID.") or CONCAT( ',', arc.typeid2, ',' ) LIKE '%,".$typeid.",%')"; 
view plaincop

到此这篇关于织梦dedecms调用得到文章所属的副栏目id及副栏目名称网址链接等就介绍到这了。积极思考造成积极人生,消极思考造成消极人生。更多相关织梦dedecms调用得到文章所属的副栏目id及副栏目名称网址链接等内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!

您可能有感兴趣的文章
织梦Linux下安装DedeCMS及安全设置

织梦dede后台缩略图本地上传图片加水印

织梦dede数据还原更新缓存也生成了为什么首页不对

织梦dede文档置顶并显示置顶文字或图标

织梦dede在搜索结果页添加按栏目按模型细分数据