织梦园模板网专注于织梦企业模板、DeDe整站模板、织梦Html5模板等织梦模板的下载,提供DEDE织梦模板相关服务。织梦园织梦模板交流群
用户名:
密码:
注册

织梦园,DEDE企业模板

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

admin / 2017-10-10 / 收藏

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

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

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

 

模板标签代码为

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


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

 
  1. //得到副栏目信息,并组织字符串  
  2. function get_url_by_typeid2($typeid2){  
  3.         $arrs=explode(",",$typeid2);//解析副栏目字段  
  4.         if($typeid2==0){  
  5.         return '';  
  6.         }else{  
  7.         $url='';  
  8.         foreach($arrs as $v){  
  9.             $url.='<a href="javascript:"  onclick="javascript:change_tab('.$v.');">'.get_typename($v).'</a>';  //此段为输出的样式,可以修改样式代码
  10.         }  
  11.         return $url;  
  12.         }  
  13. }  
  14. //织梦根据栏目编号typeid调用typename栏目名  
  15. function get_typename($typeid){  
  16.     global $dsql;  
  17.     $rs=$dsql->getOne("select typename from dede_arctype where id='$typeid'");  
  18. return $rs['typename'];  

另外特别注意,织梦标签artlist不能调用副栏目中的文章内容的问题,即文章属于互联网这个副栏目,但互联网栏目中却不显示这个文章.

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

295到296行修改

原代码

  1. if($CrossID==''$orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).')';  
  2. else $orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).','.$CrossID.')';  

修改为
  1. if($CrossID=='')  
  2. $orwheres[] = " (arc.typeid in (".GetSonIds($typeid).") or arc.typeid2 in (".GetSonIds($typeid).") or CONCAT( ',', arc.typeid2, ',' ) LIKE '%,".$typeid.",%' )";  
  3. else  
  4. $orwheres[] = " (arc.typeid in (".GetSonIds($typeid).",".$CrossID.") or arc.typeid2 in (".GetSonIds($typeid).",".$CrossID.") or CONCAT( ',', arc.typeid2, ',' ) LIKE '%,".$typeid.",%')";
收缩