服务报价 | 域名主机 | 网络营销 | 软件工具| [加入收藏]
 热线电话: #
当前位置: 主页 > php教程 > dedecms教程 >

让dedecms的channelartlist标签支持channelid属性

时间:2014-05-23 08:02来源:未知 作者:最模板 点击:
dedecms问题:一个顶级栏目中,包含了文章模型,图片等模型的栏目,现在需求,只是将文章模型的栏目搜出来,但是不能用typeid来指定.指定特定的频道模型内容在列表显示。 让dede:ch
dedecms问题:一个顶级栏目中,包含了文章模型,图片等模型的栏目,现在需求,只是将文章模型的栏目搜出来,但是不能用typeid来指定.指定特定的频道模型内容在列表显示。
让dede:channelartlist支持channelid调用。 如:{dede:channelartlist channelid='1'}
解决:打开include/taglib/channelartlist.lib.php

1.   找到代码
  //处理标记属性、innertext
    $attlist = 'typeid|0,row|20,cacheid|';
修改成
    $attlist = 'typeid|0,row|20,cacheid|,channelid|';
2. 找到

//获得类别ID总数的信息
    $typeids = array();
 
    if($typeid==0 || $typeid=='top') {
        $tpsql = " reid=0 AND ispart<>2 AND ishidden<>1 AND channeltype>0 ";
    }
    else
    {
        if(!preg_match('#,#', $typeid)) {
            $tpsql = " reid='$typeid' AND ispart<>2 AND ishidden<>1 ";
        }
        else {
            $tpsql = " id IN($typeid) AND ispart<>2 AND ishidden<>1 ";
        }
    }

在其后增加
if (!empty($channelid)) {
        $tpsql .= " and channeltype in ($channelid)";
    }

这个语句必须加在之后,
  $dsql->SetQuery("SELECT id,typename,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath 
                                            FROM `zuimoban_arctype` WHERE $tpsql ORDER BY sortrank ASC LIMIT $totalnum");
语句之前。 最模板标红了增加语句,请仔细比较,以免混淆!

(责任编辑:最模板)
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------