欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

使用jquery获取网页中图片高度的两种方法

程序员文章站 2023-11-12 19:10:34
使用jquery获取网页中图片的高度其实很简单,有两种常用的方法都可以打到我们的目的 . 代码如下: $("img").whith();(返回纯数字) $("img&...

使用jquery获取网页中图片的高度其实很简单,有两种常用的方法都可以打到我们的目的

. 代码如下:


$("img").whith();(返回纯数字)
$("img").css("width");(返回字符串:数字+"px")


但是有时候会遇到返回0的情况,上面方法返回值竟然是0或者0px,很让人诧异

方法一

在很早之前,我使用的解决方法,这也是我的师傅告诉我的解决方法:在你需要获取到的图片的<img>标签上加上width属性,或者在css中写出来图片的告诉,这样就可以了,所以每次我要去获取一个图片的高度的时候,都需要去先测量一下图片的高度,然后写到网页中,这样才可以,是不是很笨拙啊,下面我们来看第二个方法。

方法二

最近在看learning jquery英文版原著,正因为一边翻译,一边,所以每一页都看的很仔细,于是终于仔细阅读体会了以下两种常用的jquery事件加载的方法

. 代码如下:


$(function(){});
window.onload=function(){}


第一个呢,是在dom结构渲染完成以后调用的,这时候网页中一些资源还没有加载,比如图片等资源,但是dom结构已经渲染成功了
第二个呢,是在网页dom结构渲染完成,而且资源已经加载成功以后调用的。

有没有感受出区别来呢,一个是在资源没有加载的时候调用的,一个是在资源加载结束,页面已经渲染之后调用的,所以当我们在$(function(){})调用$('img').width()的时候,由于图片还没有加载,所以这时候<img>标签的高度就是0,所以返回值就是0。但是当你用window.onload=function(){}调用的时候,图片已经加载出来了,所以这时候就能得到图片的高度。

所以记得,$(function(){})是在dom渲染结束,资源还没有加载的时候执行的,如果你想获取到一些资源的信息,这个时候是没有办法的哦。