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

    织梦二次开发调用指定模型自定义字段值的文章列表
    POST TIME:2021-05-23 02:54

    有的时候,我们自定义select 、 checkbox等类型的字段。再调用文章列表时,想调用某个指定自定义字段值的文章列表。例如 color:紫色,黑色,绿色。想调用 color值都等于绿色的文章。织梦58通过 dede:sql 标签,找到了调用方法。

    有时候要调用属于某个设计师的所有案例

     

    调用方法

    在模板中,加入以下调用代码

     

        {dede:sql sql="SELECT addon.*,arc.* FROM dede_addonarticle as addon JOIN dede_archives as arc ON addon.aid=arc.id WHERE addon.color='绿色'  arc.typeid='7'  and  arc.writer=~writer~  order by id desc limit 0,10}

        <div><a href="[field:id function='GetOneDocUrl(@me)'/]">[field:title/]</a></div>

    <img src="[field:litpic/]"/>

        {/dede:sql}

     

    /*

    *  arc.typeid=7   调用ID为7的栏目  如果不需要指定栏目ID  那么你可以把 arc.typeid='7' and  删掉

    * arc.writer=~writer~  调用当前文章的作者,调用指定的作者,可以这样写arc.writer='admin'  这样就是指定调用admin这个作者的文档

    *  LIMIT 0,10  设置要调用的条数,我这里写的是10条,自行修改.

    *  指定调用2个栏目的话  可以把where arc.typeid='7'  修改为 where arc.typeid='7' and arc.typeid='8'。这样就指定调用栏目ID 为 7和8的栏目。

    */

    [field:litpic/]调用缩略图必须用这个标签

    以上代码中,调用了一个函数GetOneDocUrl();所以,需要在 incluce/extend.func.php 文件中把该函数写上。这个函数的功能是:通过id调用文章的静态url。具体函数代码如下:

     

        function GetOneDocUrl($aid)
        {
            global $dsql;
            include_once(DEDEINC."/channelunit.func.php");
            $aid = trim(ereg_replace('[^0-9]','',$aid));
         
            $chRow = $dsql->GetOne("Select arc.*,ch.maintable,ch.addtable,ch.issystem From `dede_arctiny` arc left join `dede_channeltype` ch on ch.id=arc.channel where arc.id='$aid' ");
         
            if(!is_array($chRow)) {
                return $reArr;
            }
            else {
                if(empty($chRow['maintable'])) $chRow['maintable'] = 'dede_archives';
            }
         
            if($chRow['issystem']!=-1)
            {
                $nquery = " Select arc.*,tp.typedir,tp.topid,tp.namerule,tp.moresite,tp.siteurl,tp.sitepath
                            From `{$chRow['maintable']}` arc left join `dede_arctype` tp on tp.id=arc.typeid
                            where arc.id='$aid' ";
            }
            else
            {
                $nquery = " Select arc.*,1 as ismake,0 as money,'' as filename,tp.typedir,tp.topid,tp.namerule,tp.moresite,tp.siteurl,tp.sitepath
                            From `{$chRow['addtable']}` arc left join `dede_arctype` tp on tp.id=arc.typeid
                            where arc.aid='$aid' ";
            }
         
            $arcRow = $dsql->GetOne($nquery);
         
            $Url = GetFileUrl($aid,$arcRow['typeid'],$arcRow['senddate'],$reArr['title'],$arcRow['ismake'],$arcRow['arcrank'],
            $arcRow['namerule'],$arcRow['typedir'],$arcRow['money'],$arcRow['filename'],$arcRow['moresite'],$arcRow['siteurl'],$arcRow['sitepath']);
            return $Url;
        }

     

    解释:

     

    1、注意表的前缀,这里写的是默认 dede_

    2、dede_addonarticle 为自定义模型的,表名称,如果是图集模型,请改成  dede_addonimages。

    3、limit 0,10 调用文章数量,这里是10篇


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

    截屏,微信识别二维码

    微信号:veteran88

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

     打开微信

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