帮助中心
40
最新文章
  • DeDecms迁移数据提示dede_advancedsearch’ doesn’t exist的解决方法
  • 织梦程序复制的文章如何批量取消原文的超链接
  • DeDecms如何实现当天发表的文章日期以红色显示
  • DeDecms连接数据库失败的原因和解决方法
  • 织梦程序后台高级编辑器添加图像时如何解除高度锁定比例呢?
  • 织梦DeDecms无法自动提取缩略图的两种解决方法适用于虚拟主机
  • Dedecms如何显示文章数量的方法
  • DeDecms后台管理搜索实现全文搜索文章内容
  • DeDecms友情链接LOGO滚动展示
  • DeDecms搜索结果如何按点击率排序
  • 文章分类
  • 171CMS_711CMS
  • BIWEB商务智能网站系统
  • BO-BLOG开源博客系统相关
  • cmseasy易通企业系统相关
  • Cscms程氏内容管理系统
  • dedecms教程_织梦系统帮助文档_dedecms虚拟主机空间
  • Destoon开源b2b系统相关
  • DirectAdmin(DA)用户面板相关
  • discuz论坛_discuz x3.0教程_discuz x3.2教程_DZ论坛
  • DouPHP轻量级企业网站管理系统
  • drupal开源内容管理系统(CMS)
  • ecmall商城系统教程-ecmall最新版本-ecmall模版教程
  • Ecshop开源网店系统相关
  • ECTouch程序相关教程
  • ESPCMS_易思
  • ftp教程_ftp上传工具_ftp软件_ftp是什么
  • iwebshop开源网店系统相关
  • joomla开源cms相关
  • KingCMS内容管理系统
  • Lifetype开源博客相关
  • Magento开源电子商务系统
  • mambors开源cms相关
  • mediawiki开源百科系统相关
  • Metinfo(米拓)CMS教程-米拓模版安装教程
  • modoer3.2_modoer点评系统_modoer模版
  • MvMmall多用户商城系统
  • mysql数据库相关
  • opensns开源社交系统
  • oscommerce电子商务系统
  • PHPBB开源论坛程序相关
  • phpcms教程_phpcms漏洞修复_phpcms技术中心
  • phpmyfaq开源问答(FAQ)系统相关
  • phpweb程序_phpweb教程_phpweb成品网站
  • PHPWIND开源论坛系统相关
  • phpyun
  • php主机产品
  • Pmwiki开源百科程序
  • SemCms开源程序
  • ShopEx网店程序_shopex模板教程_shopex虚拟主机空间
  • ShopNc开源商城系统教程_电子商务系统教程
  • Thinkphp中文WEB应用开发框架相关
  • thinksns全平台综合型社交系统
  • Typecho开源博客系统相关
  • WordPress博客中文教程_wordpress模板教程_wordpress虚拟主机空间
  • XOOPS内容管理系统(CMS)
  • YOUDIANCMS内容管理系统
  • zblog博客程序教程_zblog模版问题解决方法
  • Zen Cart开源商城系统相关
  • 主机环境配置相关
  • 其他资料
  • 域名相关
  • 安全资讯
  • 宏博cms企业系统相关
  • 帝国CMS教程_帝国CMS常见问题解决方法
  • 建站之星教程_建站之星程序常见问题解决方案
  • 无忧主机原创视频教程
  • 无忧主机用户部署安装网站
  • 无忧主机超级用户管理系统相关
  • 易企cms企业系统相关
  • 最土团购程序_最土团购程序模板教程_最土团购虚拟主机空间
  • 海盗云商系统
  • 网站SEO教程_SEO是什么?_SEO博客-无忧主机
  • 网站迁移和数据备份相关
  • 资源目录
  • 骑士cms_骑士人才系统教程
  • Dedecms怎么使用arclist标签中idlist进行文章排序

    平时无忧主机小编在dedecms技术群里面看见站长朋友们做站的时候,排序总是一个头痛的问题,DedeCMS默认的文章排序功能已经非常强大了,但是唯一缺少的就是,按指定的id顺序排序,无忧主机小编今天想着这个问题就睡不着,经过左思右百度,终于把这个问题解决了,DedeCMS默认的arclist标签有一个idlist调用指定id的文章,所以无忧主机小编就想到了,就利用这个idlist进行排序,下面先上方法,再说原理。先打开/include/taglib/arclist.lib.php 所有的修改都是在这里面完成的。
    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排序了

    本文地址:http://www.51php.com/dedecms/15627.html