|
同样是做公司的装修站,要在一个专题页下面调用案例的文章,这次的调用比较诡异,不仅要调用自定义字段还要调用文章的前三张图片来展示出来,效果如下:
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,; //第三张图片的调用
依次类推,我们可以初步实现很多图片的调用了,这个方法不仅适用于自定义字段还适用于文章页等,唯一要变的就是换下查询的表名和字段名就可以了。 |
|