WordPress中如何获取图片真实宽度?可以使用php函数获取吗?

WordPress中如何获取图片真实宽度?可以使用php函数获取吗?,第1张

参考:
function wpdit_get_post_images($post_content){ preg_match_all('|<imgsrc=[\'"]()[\'"]>|i', do_shortcode($post_content), $matches); if($matches){ return $matches;//自行var_dump($matches)就可以看到效果了。 }else{ return false; } }

微信小程序获取高度的方法有多种,以下是其中几种常用的方法:
1 使用wxgetImageInfo()方法获取信息,包括的宽、高等信息,代码如下:
wxgetImageInfo({
src: '路径',
success: function (res) {
consolelog(reswidth) // 宽度
consolelog(resheight) // 高度
}
})
2 使用Image对象获取高度,代码如下:
var img = new Image()
imgonload = function () {
consolelog(imgheight) // 高度
}
imgsrc = '路径'
3 使用小程序自带的组件,如image标签,通过bindload事件获取高度,代码如下:
<image src="路径" bindload="getImageHeight"></image>
getImageHeight: function (e) {
consolelog(edetailheight) // 高度
}
以上是微信小程序获取高度的几种方法,开发者可根据实际需求选择适合自己的方法。

在我们设计网页的时候,经常会遇到自适应问题,实际这些工作完全可以交给浏览器来完成就可以了,只可惜,无论是IE还是FIREFOX在自适应这个问题上都处理的不尽人意,网上实现网页宽度和高度的方法也很多,主要又两种:

第一种是使用CSS来完成;第二种是使用Javascript来完成,根据实际的应用效果来说,使用Javascript还是比较靠谱一点,因为CSS的expression的确有点烦,笔者是指使用效果上有点恼人,本文专门把这两种都总结一下,方便站长们参考使用。

一、使用CSS实现的自适应

使用CSS实现自适应很简单,主要靠两个参数来完成,分别是max-width和max-height,这两个参数在FIREFOX和IE7以上支持都很好,但是在IE6上面,效果非常糟糕,尤其是对于多张的显示,第一次显示网页大都很难达到自适应的效果,一般都是有些能自适应,有些不能自适应,多次刷新可能又显示OK,就是这点就足够烦人,而且一旦显示多张,IE6上就卡的要命(expression在IE上比较占用资源,感觉设计是用来玩得,FIREFOX自适应效果还是比较好,速度也非常快),反正笔者至今是没有找到更好的CSS方法来让IE6完美支持自适应。示例代码如下:

img{

max-width:128px;

max-height:128px;

height:auto;

zoom:expression(function(e){

if(ewidth>eheight){if(ewidth>128){eheight=eheight(128/ewidth);ewidth=128;}}

else{if(eheight>128){ewidth=ewidth(128/eheight);eheight=128;}}

estylezoom='1';}(this));

overflow:hidden;

}

上面代码格式上需要特别注意两点:

1、zoom属性里宽高赋值不能带单位(如px),否则无效;

2、if和else语句也必须带大括号括起来,单句指令也不行(而在很多编程语言里,单句指令可以无需大括号);

二、使用Javascript实现的自适应

使用Javascript自适应相对来说比较方便,唯一的麻烦是就是在网页中需要对image预设置onload事件处理resize()函数,如果对于动态网页来说还好一点,反正是动态的,程序里加上去就OK了,可是如果对于很多篇文章而言,在里头增加onload函数有点麻烦,除非一次性的写个脚本批量处理,否则后期更改或替换起来还是比较麻烦,比如的可显示宽度变化等等。

另一方面如果把宽度值写在Javascript中,那么将带来程序的通用性降低,下面的示例不是写死的,已测试效果比起CSS要HAPPY的多,网上也又很多类似的例子,不是不完成就是中间还存在某些问题,本文的例子应该会更好一点,笔者对不同的尺寸下的的显示效果做过好几种测试了。示例如下:

//RESIZE自适应宽度和高度

//参数说明:

//obj是对象,this调用方法见下面示例

//maxW和maxH分别为约定的最大宽度和最大高度

functionresizeimg(obj,maxW,maxH)

{

varimgW=objwidth;

varimgH=objheight;

if(imgW>maxW||imgH>maxH)

{

varratioA=imgW/maxW;

varratioB=imgH/maxH;

if(ratioA>ratioB)

{

imgW=maxW;

imgH=maxW(imgH/imgW);

}

else

{

imgH=maxH;

imgW=maxH(imgW/imgH);

}

objwidth=imgW;

objheight=imgH;

}

}

我们在制定宽度和高度值的时候,一般宽度是肯定需要限定,而高度经常不需要限制,所以可以把高度指定的大一点,如果高度也限制,那么相当于制定一个imagebox,下面的程序或许对您很有用(不限制高度的忽略下面这个示例)。

当指定BOX的时候,一般都还需要在自适应之后显示在BOX容器的中间,也就是水平和垂直都需要居中。首先需要指定BOX容器的宽度和高度,然后可以使用CSS来控制显示效果,也可以使用Javascript控制显示效果。示例如下:

CSS显示方法如下:

#imgbox{text-align:center;vertical-align:middle;}

#imgboximg{vertical-align:middle;}

或使用Javascript完成:

在上文resizeimg()函数里最后只需要增加类似这样的语句,

objstylemargin-left=(800-imgW)/2;

objstylemargin-top=(800-imgH)/2;

即可,当然了,您总不能让resize尺寸本来就超出BOX容器尺寸吧,否则就把容器撑大,style风格肯定就对不上了。

方法一:获取的宽高。可以用offsetWidth和offsetHeight;

方法二:

你先获取img标签标签元素。用getElementById()或者getElementsByClassName或者getElementsByTagName()都可以。

获取之后,如果你的img有width和height 属性,可以直接用img元素对象点属性

documentgetElementsByTagName("img")[0]width;

documentgetElementsByTagName("img")[0]height;

3如果img元素本身没有width和height属性。你可以获取img元素的style样式

function getStyle(obj,attr){

return objcurrentStyleobjcurrentStyle[attr]:getComputedStyle(obj)[attr];

};

obj是你的img标签对象,attr是你的想要获取的属性;

currentStyle支持IE低版本浏览器,

getComputedStyle支持主流浏览器

您好,我来为您解答: opencv,先img = loadimage,然后imgwidth(),imgHeihgt()即是图像的宽和高 cximage中也有现成的函数。 希望我的回答对你有帮助。

给img添加加载事件,图像加载完成才能获取的尺寸。
html中添加onload
function showSize(img){
alert(imgwidth);
alert(imgheight);
}
<div style="width:100px;height:600px"><img src="1jpg" onload="showSize(this)"></div>
或者js代码中添加onload
let img=documentquerySelector("div img");
imgonload = function() {
alert(imgheight);
alert(imgwidth);
}

1、界面中有一个img,但是没有用js来设置它的宽度高度和背景颜色。

2、接着使用jQuery获取到所要设置的div,并且调用css()方法即可开始设置了。

3、在css方法即可设置,注意,里面有花括号哦,并且属性用双引号引起来。

4、同时设定多个属性,则要用逗号隔开,这样即可多个属性生效。

5、接着打开hbuilder上方浏览器小图标,开始预览。

6、最后观看效果。


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

原文地址: https://outofmemory.cn/yw/13352737.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-07-20
下一篇 2023-07-20

发表评论

登录后才能评论

评论列表(0条)

保存