js判断图片加载完成后获取图片实际宽高的方法
作者:bea
本文实例讲述了js判断图片加载完成后获取图片实际宽高的方法。分享给大家供大家参考,具体如下: 通常,我们会用jq的.width()/.height()方法获取图片的宽度/高度或者用js的.offsetwidth/.offsetheight方法来获取图片的宽度/高度,但这些方法在我们通过样式设置了图片的宽高后获取的就不是图片的实际宽高,这显然在有些时候不是我们想要的结果,那么有没有一种方法来获取这样的实际宽高呢?答案是有的。下面的代码就能解决这样的问题: <img s
本文实例讲述了js判断图片加载完成后获取图片实际宽高的方法。分享给大家供大家参考,具体如下:
通常,我们会用jq的.width()/.height()方法获取图片的宽度/高度或者用js的.offsetwidth/.offsetheight方法来获取图片的宽度/高度,但这些方法在我们通过样式设置了图片的宽高后获取的就不是图片的实际宽高,这显然在有些时候不是我们想要的结果,那么有没有一种方法来获取这样的实际宽高呢?答案是有的。下面的代码就能解决这样的问题:
<img src="01.jpg" id="test" width="250px">
js code:
//图片加载完成后获取图片实际宽高
var _test = document.getElementById("test");
test.onload = function(){
imgSize.call(_test);
}
function imgSize(){
var imgObj = new Image();
imgObj.src = this.src;
alert(imgObj.width + "
" + imgObj.height);
}
如果想在其他方法中调用这个实际的宽高,应该将alert(imgObj.width + "
" + imgObj.height);改为return imgObj,然后是调用的方法:
window.onload = function(){
function a(){
var real= imgSize.call(_test);
var realwidth = real.width;
alert(realwidth);
}
a();
}
以上方法过于繁琐,经过本人的提炼,简写如下:
window.onload = function(){
var _test = document.getElementById("test"); //若是jq,则直接将此代码换成 var _test = $("#test"); 即可。
var imgObj = new Image();
imgObj.src = _test.src; //若是jq,则直接将此代码换成 imgObj.src = _test.attr("src"); 即可。
alert(imgObj.width);
}
这样,就可以在其他方法里直接调用图片的实际宽高了。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
猜你喜欢
您可能感兴趣的文章:
- 理解javascript中Map代替循环
- JS实现随页面滚动显示/隐藏窗口固定位置元素
- 学习使用jquery iScroll.js移动端滚动条插件
- AngularJS整合Springmvc、Spring、Mybatis搭建开发环境
- jQuery iScroll.js 移动端滚动条美化插件
- JavaScript 正则表达式中global模式的特性
- javascript动态获取登录时间和在线时长
- 基于javascript实现动态时钟效果
- jQuery使用zTree插件实现树形菜单和异步加载
- 灵活的理解JavaScript中的this指向
- jQuery插件实现表格隔行变色及鼠标滑过高亮显示效果代码
- jQuery插件实现文字无缝向上滚动效果代码
- jQuery zTree加载树形菜单功能
- JavaScript实现搜索框的自动完成功能(一)
- jquery插件之文字间歇自动向上滚动效果代码
- jQuery插件ImageDrawer.js实现动态绘制图片动画(附源码下载)
- 利用jQuery中的ajax分页实现代码
- Jquery zTree 树控件异步加载操作
- jquery插件jquery.dragscale.js实现拖拽改变元素大小的方法(附demo源码下载)