手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >jQuery获取file控件中图片的宽高与大小
jQuery获取file控件中图片的宽高与大小
摘要:问题如何判断inputfile表单里上传的图片的宽高和大小呢?解决方案这个时候图片还没真正上传,也不是在页面上展示,不能使用$(“#id”)...

问题

如何判断input file表单里上传的图片的宽高和大小呢?

解决方案

这个时候图片还没真正上传,也不是在页面上展示,不能使用$(“#id”).width(),$(“#id”).height()这种方式。

在Stack Overflow找到一个方法获取input file图片文件的宽高:

var _URL = window.URL || window.webkitURL; $("#file").change(function (e) { var file, img; if ((file = this.files[0])) { img = new Image(); img.onload = function () { alert(this.width + " " + this.height); }; img.src = _URL.createObjectURL(file); } });

发现可以用,仅在火狐中测试了,其他浏览器兼容性未知,因为后台使用,所以暂且不管兼容性,拿来封装了一下。

我把这个函数完善了一下,获取input file图片的宽高和大小,如下:

//获取input图片宽高和大小 function getImageWidthAndHeight(id, callback) { var _URL = window.URL || window.webkitURL; $("#" + id).change(function (e) { var file, img; if ((file = this.files[0])) { img = new Image(); img.onload = function () { callback && callback({"width": this.width, "height": this.height, "filesize": file.size}); }; img.src = _URL.createObjectURL(file); } }); }

这里使用了一个回调方法,回调方法的参数是这个json对象,包含宽度、高度和大小,在jQuery中这样调用:

(function () { //省略其他代码 getImageWidthAndHeight('image_file', function (obj) { if (obj.width != 843 || obj.height != 1038) { $.messager.alert('操作提示', '弹窗图片宽高必须是843*1038px'); } }); })(jQuery)

好了,这样就OK了。以上就是jQuery获取intput file图片的宽高和大小的全部内容了,相信本文的内容会对大家平时使用jQuery和图片上传的时候很有帮助的。

【jQuery获取file控件中图片的宽高与大小】相关文章:

js验证上传图片的方法

jQuery封装的tab选项卡插件分享

jQuery实现弹出窗口中切换登录与注册表单

js兼容火狐获取图片宽和高的方法

jQuery插件jRumble实现网页元素抖动

三种AngularJS中获取数据源的方式

jQuery仿gmail实现fixed布局的方法

jquery读取xml文件实现省市县三级联动的方法

JQuery中两个ul标签的li互相移动实现方法

jQuery取消ajax请求的方法

精品推荐
分类导航