织梦在发表文章时,你会发现有一个副栏目的功能.比如一个文章,他可能即属于你的科技栏目,也属于互联网栏目,那你在发表这个文章时,主栏目可以选择科技,副栏目可以在互联网上打勾选定.
文章的副栏目保存在数据库表archives中的typeid2这个字段中.
效果图.文章属于商会.及德商文化等.三个栏目.我里在栏目显示出来.点击链接后,就会进入相关的栏目中.这里是js函数的形式.只作案例演示.
模板标签代码为
{dede:arclist row='2' titlelen='100'typeid=2 orderby='id' }
[field:typename/]
[field:typeid2 function="get_url_by_typeid2(@me)"/]
{/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.='
onclick="javascript:change_tab('.$v.');">'.get_typename($v).'';
}
return $url;
}
}
//织梦根据栏目编号typeid调用typename栏目名
function get_typename($typeid){
global $dsql;
$rs=$dsql->getOne("select typename from arctype where id='$typeid'");
return $rs['typename'];
}
另外特别注意,织梦标签artlist不能调用副栏目中的文章内容的问题,即文章属于互联网这个副栏目,但互联网栏目中却不显示这个文章.
需要修改系统文件./include/taglib/arclist.lib.php
295到296行修改
原代码
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.",%')";