您现在的位置是:首页 > 教程 > dedecms教程dedecms教程
dedecms怎么使用ARCLIST标签中IDLIST进行文章排序的方法
邬肖任2023-09-19 17:34:09dedecms教程已有人查阅
导读平时代码号看见站长朋友们做站的时候,排序总是一个头痛的问题,DedeCMS默认的文章排序功能已经非常强大了,但是唯一缺少的就是,按指定的id顺序排序,代码
平时代码号看见站长朋友们做站的时候,排序总是一个头痛的问题,DedeCMS默认的文章排序功能已经非常强大了,但是唯一缺少的就是,按指定的id顺序排序,代码号小编经过左思右想,终于把这个问题解决了,DedeCMS默认的arclist标签有一个idlist调用指定id的文章,所以代码号小编就想到了,就利用这个idlist进行排序,下面先上方法,再说原理。先打开/include/taglib/arclist.lib.php 所有的修改都是在这里面完成的。
1、找到return lib_arclistDone 这段代码,在其前面加上$orderidlist = $ctag->GetAtt(‘orderidlist’); 并且在lib_arclistDone函数调用的之后面加上参数$orderidlist,代码如下:
1、找到return lib_arclistDone 这段代码,在其前面加上$orderidlist = $ctag->GetAtt(‘orderidlist’); 并且在lib_arclistDone函数调用的之后面加上参数$orderidlist,代码如下:
$orderidlist = $ctag->GetAtt(‘orderidlist’);
return lib_arclistDone
(
$refObj, $ctag, $typeid, $ctag->GetAtt(‘row’), $ctag->GetAtt(‘col’), $titlelen, $infolen,
$ctag->GetAtt(‘imgwidth’), $ctag->GetAtt(‘imgheight’), $listtype, $orderby,
$ctag->GetAtt(‘keyword’), $innertext, $envs[‘aid’], $ctag->GetAtt(‘idlist’), $channelid,
$ctag->GetAtt(‘limit’), $flag,$ctag->GetAtt(‘orderway’), $ctag->GetAtt(‘subday’), $ctag->GetAtt(‘noflag’),
$tagid,$pagesize,$isweight,$orderidlist
);
2、找到function lib_arclistDone这段代码,在函数lib_arclistDone的之后加上参数$orderidlist=’N’,代码如下:
function lib_arclistDone(&$refObj, &$ctag, $typeid=0, $row=10, $col=1, $titlelen=30, $infolen=160,
$imgwidth=120, $imgheight=90, $listtype=’all’, $orderby=’default’, $keyword=”,
$innertext=”, $arcid=0, $idlist=”, $channelid=0, $limit=”, $att=”, $order=’desc’, $subday=0, $noflag=”,$tagid=”, $pagesize=0, $isweight=’N’,$orderidlist=’N’)
3、找到$innertext = trim($innertext); ,在其下面加上$orderidlist = AttDef($orderidlist,’N’);代码如下:
$orderby = strtolower($orderby);
$keyword = trim($keyword);
$innertext = trim($innertext);
$orderidlist = AttDef($orderidlist,’N’);
$tablewidth = $ctag->GetAtt(‘tablewidth’);
$writer = $ctag->GetAtt(‘writer’);
if($tablewidth == “”) $tablewidth = 100;
4、搜索“//指定了id或使用缓存中的id” 把下面的条件语句改成:
//指定了id或使用缓存中的id
if($idlist != ”)
{
$query = “SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,tp.namerule2,tp.ispart,
tp.moresite,tp.siteurl,tp.sitepath
$addfieldsSql
FROM `$maintable` arc left join `dede_arctype` tp on arc.typeid=tp.id
$addfieldsSqlJoin
WHERE arc.id in($idlist) “;
if($orderidlist == ‘N’) {
$query .= $ordersql;
} else {
$query .= ” ORDER BY FIELD(arc.id,$idlist) “;
}
}
这样就对arclist添加了一个orderidlist属性,有参数Y/N, 默认为N,为Y的时候,就可以按idlist 排序了。其实这个原理也非常简单,就是利用的MYSQL数据库的ORDER BY FIELD功能。所以这样我们就可以使用idlist排序了
本文标签:
很赞哦! ()
相关文章
随机图文
-
织梦dedecms如何用sql语句删除全部文章和删除所有数据
有时候为了网站测试数据和功能,就采集或者添加了很多文章,但是网站上线的时候这些文章都是需要删除的,很多朋友都问我,怎么在织梦后台用sql语句把文章都全部删除掉 -
dede织梦实现js调用站外内容的方法
dedecms使用js调取网站内容,然后在其他网站使用,这样可以实现同步更新。达到此网站更新,站外的内容也更新。 -
dedecms织梦程序给栏目增加缩略图的方法示例
有时候因为网站功能需求,我们需要为织梦程序的栏目页添加缩略图功能,这里有一个栏目添加缩略图的方法,供大家参考。 -
织梦DedeCMS判断简略标题为空则显示完整标题的方法
相信大家都遇到过,我们在使用织梦DedeCMS系统程序开发网站中,会遇到很多因网页版面设计限定的宽度,使文章标题需要进行字数限制,通常做法是在a标签中加入一个title属性
留言与评论 (共有 条评论) |