欢迎您光临深圳塔灯网络科技有限公司!
电话图标 余先生:13699882642

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

发表日期:2017-07 文章编辑:小灯 浏览次数:1812

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

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

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

模板标签代码为view plaincop

{dede:arclist row='2' titlelen='100'typeid=2 orderby='id' }<span><ahref="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 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


本页内容由塔灯网络科技有限公司通过网络收集编辑所得,所有资料仅供用户参考了本站不拥有所有权,如您认为本网页中由涉嫌抄袭的内容,请及时与我们联系,并提供相关证据,工作人员会在5工作日内联系您,一经查实,本站立刻删除侵权内容。本文链接:https://www.dengtar.com/11232.html
相关cms文章
    SQL执行错误,请检查