注册 登录 欢迎您访问极限源码网:专注各类网站源码下载。

织梦基础知识

该栏目分享织梦建站的基础知识,从织梦CMS的安装,到织梦标签的常规调用,以及织梦的常见问题答疑都有涉及。

当前位置:网站首页 > 建站学院 > 织梦教程 >

拓展channel标签实现limit功能

admin 2014-10-03 15:07 织梦教程

由于网站栏目多次需要调用同一栏目下的栏目比如顶级栏目6 下级栏目5.4.3.2.1 需要分两次分别调出543和21 感觉channel就比较吃力了全部写SQL又太多,可能是我还不知道有其他方法吧。row调用不出这种效果所以就把row改为了Limit用法了比较方便 修改文件include\taglib/下面的channel.lib.php 在函数lib_channel里面加上

//limit条件
    $limit = trim(eregi_replace('limit','',$limit));
    if($limit!='') $limitsql = " limit $limit ";
    else $limitsql = " limit 0,7 ";
 
    $orwhere = '';
    if(isset($orwheres[0])) {
        $orwhere = join(' And ',$orwheres);
        $orwhere = ereg_replace("^ And",'',$orwhere);
        $orwhere = ereg_replace("And[ ]{1,}And",'And ',$orwhere);
    }
    if($orwhere!='') $orwhere = " where $orwhere ";//二次开发





--------------------------------------------------------------------------------

把上面的代码,添加到函数lib_channel(具体位置为:)

function lib_channel(&$ctag,&$refObj)
{
    global $dsql;
 
    $attlist = "typeid|0,reid|0,row|100,col|1,type|son,currentstyle|,cacheid|";
    FillAttsDefault($ctag->CAttribute->Items,$attlist);
    extract($ctag->CAttribute->Items, EXTR_SKIP);
    $innertext = $ctag->GetInnerText();
    $line = empty($row) ? 100 : $row;



----------------------------------------------------------
这段代码后面
所有查询条件的limit 0,$row改为$limitsql OK 保存

服务项目

源码下载

关于我们

极限源码网| https://www.jxym.net

极限源码网(JXYM.NET)由一批热爱网页设计、敢于追求梦想、努力付诸行动的热火青年联合打造,在我们的努力之下,让您拥有一个全方位的源码下载平台