问题
如何判断input file表单里上传的图片的宽高和大小呢?
解决方案
这个时候图片还没真正上传,也不是在页面上展示,不能使用$(“#id”).width(),$(“#id”).height()
这种方式。
在Stack Overflow找到一个方法获取input file图片文件的宽高:
1
2
3
4
5
6
7
8
9
10
11
|
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图片的宽高和大小,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
//获取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中这样调用:
1
2
3
4
5
6
7
8
|
( function () { //省略其他代码 getImageWidthAndHeight( 'image_file' , function (obj) { if (obj.width != 843 || obj.height != 1038) { $.messager.alert( '操作提示' , '弹窗图片宽高必须是843*1038px' ); } }); })(jQuery) |
好了,这样就OK了。以上就是jQuery获取intput file图片的宽高和大小的全部内容了,相信本文的内容会对大家平时使用jQuery和图片上传的时候很有帮助的。