时间:2021-05-26
前言
网上关于利用Javascript获取图片原始宽度和高度的方法有很多,本文将再次给大家谈谈这个问题,或许会对一些人能有所帮助。
方法详解
页面中的img元素,想要获取它的原始尺寸,以宽度为例,可能首先想到的是元素的innerWidth属性,或者jQuery中的width()方法。
如下:
这样貌似可以拿到图片的尺寸。
但是如果给img元素增加了width属性,比如图片实际宽度是600,设置了width为400。这时候innerWidth为400,而不是600。显然,用innerWidth获取图片原始尺寸是不靠谱的。
这是因为 innerWidth属性获取的是元素盒模型的实际渲染的宽度,而不是图片的原始宽度。
<img id="img" src="1.jpg" width="400"><script type="text/javascript"> var img = document.getElementById("img"); console.log(img.innerWidth); // 400</script>jQuery的width()方法在底层调用的是innerWidth属性,所以width()方法获取的宽度也不是图片的原始宽度。
那么该怎么获取img元素的原始宽度呢?
naturalWidth / naturalHeight
HTML5提供了一个新属性naturalWidth/naturalHeight可以直接获取图片的原始宽高。这两个属性在Firefox/Chrome/Safari/Opera及IE9里已经实现。
如下:
var naturalWidth = document.getElementById('img').naturalWidth, naturalHeight = document.getElementById('img').naturalHeight;naturalWidth / naturalHeight在各大浏览器中的兼容性如下:
图片截取自:http://caniuse.com/#search=naturalWidth
所以,如果不考虑兼容至IE8的,可以放心使用naturalWidth / naturalHeight属性了。
IE7/8中的兼容性实现:
在IE8及以前版本的浏览器并不支持naturalWidth和naturalHeight属性。
在IE7/8中,我们可以采用new Image()的方式来获取图片的原始尺寸,如下:
function getNaturalSize (Domlement) { var img = new Image(); img.src = DomElement.src; return { width: img.width, height: img.height };}// 使用var natural = getNaturalSize (document.getElementById('img')), natureWidth = natural.width, natureHeight = natural.height;IE7+浏览器都能兼容的函数封装:
function getNaturalSize (Domlement) { var natureSize = {}; if(window.naturalWidth && window.naturalHeight) { natureSize.width = Domlement.naturalWidth; natureSizeheight = Domlement.naturalHeight; } else { var img = new Image(); img.src = DomElement.src; natureSize.width = img.width; natureSizeheight = img.height; } return natureSize;}// 使用var natural = getNaturalSize (document.getElementById('img')), natureWidth = natural.width, natureHeight = natural.height;总结
以上就是这篇文章的全部内容,希望能对大家的学习或者工作带来一定的帮助。如果有疑问大家可以留言交流。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
微信小程序图片等比例缩放动态的获取图片的高度和宽度动态的设置图片的高度和宽度前言:在小程序布局中,如果图片不是固定高度和高度,但image设置的是固定的高度和宽
如果我们页面看到的图片都是缩略图,那就需要做个图片点击放大效果,那么怎样获取图片的原始宽高呢?方法如下://获取图片原始宽度functiongetNatural
获取或设置div的高度和宽度方法一:height和width函数(得到的是证书),可以用于获取或设置元素的高度和宽度。val()获取或设置元素的值方法二:css
HTML插入图片的正确方法是使用标记,其语法为: 该标记没有结束标记。 除SRC属性外,其它属性均可省略。 如果不指定宽度和高度,则图片采用原始大小显
本文实例讲述了Android获取屏幕或View宽度和高度的方法。分享给大家供大家参考,具体如下:在Activity中获取屏幕的高度和宽度Displaydispl