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

织梦调用自定义字段中的第一张图片(含第二张第三张),第1张

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

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

DedeCMS调用自定义字段中的第一张图片(含第二张第三张)

  

一、调用自定义字段中的第一张图片方法,打开include/extend.func.php,在最下面添加代码:

     

 //取案例第一张地址
  function GetFirstImg($arcid){
  global $dsql;
  $query= "SELECt anlsm FROM `dede_addon17` where aid='$arcid'";
  $row = $dsql->GetOne($query);
  $preg = "//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']);

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

        

  当然,如果你自定义的字段中没图片,获取的地址就是空的。

 

  二、调用自定义字段中的第二张、第三章图片方法,打开include/extend.func.php,在最下面添加代码:

      

  //取案例第二张地址
  function GetSecImg($arcid){
  global $dsql;
  $query= "SELECt anlsm FROM `dede_addon17` where aid='$arcid'";
  $row = $dsql->GetOne($query);
  $preg = "//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 = "//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']);

  这样就能调用自定义字段的第二个和第三个图片了,调用标签为:

         //第二张图片的调用

         //第三张图片的调用

  不难看出,原理都是一样的,通过数据库查找附加表中自定义字段的内容,匹配图片,而区别第一个和第二个等图片的方法就是用数组判断:

         $match[1][1]; //第二张图片的调用

         $match[1][2]; //第三张图片的调用

  依次类推,我们可以初步实现很多图片的调用了,这个方法不仅适用于自定义字段还适用于文章页等,唯一要变的就是换下查询的表名和字段名就可以了。

 

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/3010273.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-09-27
下一篇2022-09-27

发表评论

登录后才能评论

评论列表(0条)

    保存