js和jquery如何获取图⽚真实的宽度和⾼度
1、什么时候需要获取图⽚真实的宽度和⾼度
在做pc⽹页的时候,有时候会考虑按照插⼊的图⽚的尺⼨来判断图⽚是横图还是竖图。然后判断过后给予不同的展⽰⽅式!
另外⼀种就是在⼿机页⾯上,在新闻页插⼊的图⽚往往都是按照图⽚的原尺⼨来展⽰,如果⼿机屏幕太⼩,太⼤的图就会超出去!这时候有两种解决办法
1)给所有的图⽚加上这样的样式
1
复制代码代码如下:
jquery在线图片.news img{margin:5px auto; display:block;width:100%; height:auto;}
但是这种⽅式有另外⼀个问题就是,如果插⼊的图⽚本⾝就很⼩的话,也会被直接拉伸成100%显⽰,显然这是不合理的!那么这⾥就介绍另外⼀种⽅式就是通过js动态展⽰图⽚的尺⼨!
2)js动态获取图⽚的尺⼨
jquery⽅式
代码如下
var _w = parseInt($(window).width());//获取浏览器的宽度
$(".new_mess_c img").each(function(i){
var img = $(this);
var realWidth;//真实的宽度
var realHeight;//真实的⾼度
//这⾥做下说明,$("<img/>")这⾥是创建⼀个临时的img标签,类似js创建⼀个new Image()对象!
$("<img/>").attr("src", $(img).attr("src")).load(function() {
/*
如果要获取图⽚的真实的宽度和⾼度有三点必须注意
1、需要创建⼀个image对象:如这⾥的$("<img/>")
2、指定图⽚的src路径
3、⼀定要在图⽚加载完成后执⾏如.load()函数⾥执⾏
*/
realWidth = this.width;
realHeight = this.height;
//如果真实的宽度⼤于浏览器的宽度就按照100%显⽰
if(realWidth>=_w){
$(img).css("width","100%").css("height","auto");
}
else{//如果⼩于浏览器的宽度按照原尺⼨显⽰
$(img).css("width",realWidth+'px').css("height",realHeight+'px');
}
});
});
js⽅式
代码如下
function getViewSize() {//获取浏览器视⼝的宽⾼
return {
"w": window['innerWidth'] || document.documentElement.clientWidth,
(www.jb51) "h": window['innerHeight'] || document.documentElement.clientHeight
}
}
function getFullSize() {//获取浏览器最⼤的宽度
var w = Math.max(document.documentElement.clientWidth, document.body.clientWidth) +
Math.max(document.documentElement.scrollLeft, document.body.scrollLeft);
var h = Math.max(document.documentElement.clientHeight, document.body.clientHeight) +
Math.max(document.documentElement.scrollTop, document.body.scrollTop);
w = Math.max(document.documentElement.scrollWidth, w);
h = Math.max(document.documentElement.scrollHeight, h);
return {
"w": w,
"h": h
};
}
var _sv_w = getViewSize()["w"];
var _sf_w = getFullSize()["w"];
var _w = _sv_w;//这⾥⽤视⼝的宽度,具体视情况
var Imgarray = ElementsByTagName("img");
var realWidth;//真实的宽度
var realHeight;//真实的⾼度
for(var i =0;i<Imgarray.length;i++){
var imgtemp = new Image();//创建⼀个image对象
imgtemp.src = Imgarray[i].src;
imgtemp.index = i;//指定⼀个检索值,⽤于确定是哪张图
var _stemp = this;//将当前指针复制给新的变量,不然会导致变量共⽤
realWidth = this.width;
realHeight = this.height;
if(realWidth >=_w )
{
Imgarray[_stemp.index].style.width = _w+'px';
Imgarray[_stemp.index].style.height = 'auto';
}
else{
Imgarray[_stemp.index].style.width = realWidth+'px';
Imgarray[_stemp.index].style.height = realHeight+'px';
}
}
}
}
上⾯两种⽅法中jquery⽐较简单,实现起来⽐较快,第⼆种⽐较复杂些,但是执⾏起来⽐jquery要快!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论