• 全国400电话网上服务平台
    强大号码库资源任选,方便,快捷,快速开通。
    咨询热线:400-1100-266  

    织梦dedecms调用得到文章所属的副栏目id及副栏目名称网址链接等
    POST TIME:2021-05-24 03:10

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

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

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

    模板标签代码为 view plain cop

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


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

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

    295到296行修改

    原代码view plain copy

    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 plain cop

    
    关于我们 | 付款方式 | 建站知识 | 增值服务 | 网站模板
    Copyright © 2003-2016
    时间:9:00-21:00 (节假日不休)
    版权所有:巨人网络(扬州)科技有限公司
    总部地址:江苏省信息产业基地11号楼四层
    《增值电信业务经营许可证》 苏B2-20120278
    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信

    微信号已复制,请打开微信添加咨询详情!