在模板的制作过程中,我们常常会遇到需要从正文newstext中提取图片的问题,由于newstext是整块图文输出,所以我们需要对newstext正文模块进行处理,以保证我们所需要的内容是图片!
现在我们所处理的环境是内容模板,关于灵动标签在首页调用正文图片的方式大致相同,如果你实在不知道如何在灵动标签中调用正文中的图片,可以留言,有必要的我会更新关于灵动标签的文章,好了,现在我们正式开始讲解怎么在内容模板中提取正文第一张图以及多张图片,以达到不同的图片样式结构!
首先,你可能需要了解newstext的两种写法:
[!–newstext–](帝国CMS正文模块标签的标准写法)
<?=$navinfor['newstext']?>(帝国CMS灵动标签或PHP中调用时的写法)
由于需要从[!–newstext–]中提取图片,所以还需要用到的工具是正则提取,正则的话就需要用到PHP语句,所以豪不犹豫的会用到$navinfor[‘newstext’]这种写法,关于提取的语句请关注下面的代码:
<?php
$str=stripcslashes($navinfor['newstext']); //脱敏正文newstext数据
preg_match_all('/<img.*?src="(.*?)".*?>/is',$str,$imgArr); //正则提取正文图片
$imgArr = array_unique($imgArr[1]); //图片如有复生将去重复
$imgid = 0; //给定初始序号
foreach($imgArr as $vause){ //判断有多少张图
$imgid ++; //循环输出每一张图
?>
<img src="<?=$vause?>" alt="<?=$navinfor['title']?>第<?=$imgid?>张"></a> //输出的图片样式格式
<?php
};
?>
上述语句是提取的多张图片,如果你只想提取帝国CMS正文第一张图的话,那么可以这么写:
<?php
$str=stripcslashes($navinfor['newstext']); //脱敏正文newstext数据
preg_match_all('/<img.*?src="(.*?)".*?>/is',$str,$imgArr); //正则提取正文图片
$imgArr = array_unique($imgArr[1]); //图片如有复生将去重复
?>
<img src="<?=$imgArr[0]?>" alt="<?=$navinfor['title']?>"></a> //输出的图片样式格式
<?php
};
?>
修改同时得到图片和图片中title 文字方便内容页排版
<?php
$str=stripcslashes($navinfor[newstext]);
preg_match_all('/<img.*?src="(.*?)".*?>/is',$str,$imgArr);
preg_match_all('/<img.*?title="(.*?)".*?>/is',$str,$imgtitle);
$imgArr = array_unique($imgArr[1]);
$imgtitle = array_unique($imgtitle[1]);
$imgid = 0;
foreach($imgArr as $vause =>$vig ) {
//echo $vig." ".$imgtitle[$vause] ."<br>";
$vausedd = $vig;
$imgtits = $imgtitle[$vause] ;
$imgid ++;
?>
<li><a href="<?=$vausedd?>" title="<?=$navinfor
[‘title’]?>第<?=$imgid?>张" rel="clearbox[test1]"><img src="<?=$vausedd?>" alt="<?=$navinfor
[‘title’]?>第<?=$imgid?>张"/><?=$imgtits?></a></li>
<?php
};
?>