分享

php正则表达式,取img标记中任意属性,正则替换去掉或改变图片img标记中的任意属性 -...

 tianhao 2010-02-06
php正则表达式,取img标记中任意属性,正则替换去掉或改变图片img标记中的任意属性
[ 时间:2009-08-06 09:59:17 | 浏览:1359 次 | 来源: | 作者: ]

本文word版下载:http://www./upload/edit_pic/20090806101735.doc

本文txt版下载:http://www./upload/edit_pic/20090806102141.txt

一次做新闻系统时因为要固定新闻页图片的大小并且要加链接,因此就去网上找,结果还真找到了,首页把新页实现代码贴出来:

$as_message = preg_replace(\'/<img.+src=\"?(.+\.(jpg|gif|bmp|bnp|png))\"?.+>/i\', "<a href=\"$1\" target=_blank title=点击放大图片><img src=\"$1\" border=0 onload=\"javascript:if(this.width>screen.width-600)this.width=screen.width-600\"  onmousewheel=\"return bbimg(this)\" ></a>", $as_message);
$as_message = preg_replace(\'/<IMG.+SRC=\"?(.+\.(jpg|gif|bmp|bnp|png))\"?.+>/i\', "<a href=\"$1\" target=_blank title=点击放大图片><img src=\"$1\" border=0 onload=\"javascript:if(this.width>screen.width-600)this.width=screen.width-600\"  onmousewheel=\"return bbimg(this)\" ></a>", $as_message);

另一种固定图片的js方法:

<table width="90%" border="0" cellpadding="0" cellspacing="0" id="abc">
  <tr>
    <td> </td>
  </tr>
</table>
<script>
var abc=document.getElementById("abc");
var imgs=abc.getElementsByTagName("img");
for (var i=0,g;g=imgs[i];i++)
g.onload=function(){if (this.width>600){this.width=600}else{if (this.height>600)this.height=600}}
</script>

 

参考如下:

因有一项目新闻发布系统,数据库内容字段中存储的是原图的路径(当然还有其他文字内容啦,内容里插图时,存的是图片路径),但前台想使用缩略图,琢磨1小时余,得到以下结果,可解决问题(取img标签会了,取别的标签任意属性自然也会了):


<?php
/*正则取图片img标记中的任意属性*/
$word = \'<p height="22" align="cenetr">111 22</p> <img  height="60" src="/upload/images/aaa.jpg"    width=100 style=><div style="float:left;">中国人</div>\';
//取width
preg_match(\'/<img.+(width=\"?\d*\"?).+>/i\',$word,$matches);
echo $matches[1];

//取height
preg_match(\'/<img.+(height=\"?\d*\"?).+>/i\',$word,$matches);
echo $matches[1];

//取src
preg_match(\'/<img.+src=\"?(.+\.(jpg|gif|bmp|bnp|png))\"?.+>/i\',$word,$matches);
echo $matches[1];

/*正则替换去掉或改变图片img标记中的任意属性***************************************************************/
$str = \'<p height="22" align="cenetr">111 22</p> <img  height="60" src="/upload/images/aaa.jpg"    width=100 style=><div style="float:left;">中国人</div>
<p height="22" align="cenetr">31313 224344</p> <img src="/upload/images/bbb.jpg"  height="60"    width=100 style=><div style="float:left;">1212121</div>\';


//改变src属性(此处将原来的src="/upload/images/bbb.jpg"改变为src="/upload/_thumbs/Images/bbb.jpg")
print preg_replace(\'/(<img.+src=\"?.+)(images\/)(.+\.(jpg|gif|bmp|bnp|png)\"?.+>)/i\',"\${1}_thumbs/Images/\${3}",$str);


/*改变src属性,
此处将原来的src="/upload/images/bbb.jpg"改变为src="/upload/_thumbs/Images/bbb.jpg",并舍弃宽和高
(比如你想在前台显示缩略图,但数据库中存储的是原图的路径。为什么要舍弃宽高??你缩略图啊!还是原图的宽高,会怎样???)
*/
print preg_replace(\'/(<img).+(src=\"?.+)images\/(.+\.(jpg|gif|bmp|bnp|png)\"?).+>/i\',"\${1} \${2}_thumbs/Images/\${3}>",$str);

?>

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多