找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 177|回复: 0

[cms教程] 织梦调用自定义字段中的第一张图片(含第二张第三张)

[复制链接]

该用户从未签到

发表于 2021-3-22 10:52:37 | 显示全部楼层 |阅读模式

您需要 登录 才可以下载或查看,没有账号?立即注册

×
同样是做公司的装修站,要在一个专题页下面调用案例的文章,这次的调用比较诡异,不仅要调用自定义字段还要调用文章的前三张图片来展示出来,效果如下:



                               
登录/注册后可看大图



        DedeCMS调用自定义字段中的第一张图片(含第二张第三张)
         
        一、调用自定义字段中的第一张图片方法,打开include/extend.func.php,在最下面添加代码:
       
       
               
                       
                               
                                       
//取案例第一张地址
        function GetFirstImg($arcid){
        global $dsql;
        $query= "SELECT anlsm FROM `dede_addon17` where aid='$arcid'";
        $row = $dsql->GetOne($query);
        $preg = "/
[img][/img]
/i";
        preg_match_all($preg, $row['anlsm',, $match);
        //print_r($match);
        return $match[1,[0];
        }
                               
                       
               
       


        再打开include/taglib/arclist.lib.php,搜索代码(大概在第514行):
         
                
       
               
                       
                               
                                       
$row['fulltitle', = $row['title',;
                               
                       
               
       

         
        在下面添加代码:
         
       
               
                       
                               
                                       
$row['firstimgurl', = GetFirstImg($row['id',);
                               
                       
               
       

       
        这样就能调用自定义字段的第一个图片了,调用标签为:
         
       
               
                       
                               
                                       
[img][/img]
                               
                       
               
       

         
        当然,如果你自定义的字段中没图片,获取的地址就是空的。
         
        二、调用自定义字段中的第二张、第三章图片方法,打开include/extend.func.php,在最下面添加代码:
       
       
               
                       
                               
                                       
//取案例第二张地址
       function GetSecImg($arcid){
       global $dsql;
       $query= "SELECT anlsm FROM `dede_addon17` where aid='$arcid'";
       $row = $dsql->GetOne($query);
       $preg = "/
[img][/img]
/i";
       preg_match_all($preg, $row['anlsm',, $match);
       //print_r($match);
       return $match[1,[1,;
       }
                               
                       
               
       


       
               
                       
                               
//取案例第三张地址
        function GetThirImg($arcid){
        global $dsql;
        $query= "SELECT anlsm FROM `dede_addon17` where aid='$arcid'";
        $row = $dsql->GetOne($query);
        $preg = "/
[img][/img]
/i";
        preg_match_all($preg, $row['anlsm',, $match);
        //print_r($match);
        return $match[1,[2,;
        }
                       
               
       



        再打开include/taglib/arclist.lib.php,搜索代码(大概在第514行):
         
       
               
                       
                               
                                       
$row['fulltitle', = $row['title',;
                               
                       
               
       

         
        在下面添加代码:
         
                
       
               
                       
                               
                                       
$row['secondimgurl', = GetSecImg($row['id',);
$row['thirdimgurl', = GetThirImg($row['id',);
                               
                       
               
       

         
        这样就能调用自定义字段的第二个和第三个图片了,调用标签为:
         
       
[img][/img]
//第二张图片的调用
         
       
[img][/img]
//第三张图片的调用
         
        不难看出,原理都是一样的,通过数据库查找附加表中自定义字段的内容,匹配图片,而区别第一个和第二个等图片的方法就是用数组判断:
         
        $match[1,[1,; //第二张图片的调用
         
        $match[1,[2,; //第三张图片的调用
         
        依次类推,我们可以初步实现很多图片的调用了,这个方法不仅适用于自定义字段还适用于文章页等,唯一要变的就是换下查询的表名和字段名就可以了。
回复

使用道具 举报

网站地图|页面地图|文字地图|Archiver|手机版|小黑屋|找资源 |网站地图

GMT+8, 2024-12-28 18:41

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表