mysql读取图片数据宽度_jQuery获取file控件中图片的宽高与大小

问题

如何判断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和图片上传的时候很有帮助的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值