jQuery获取file控件中图片的宽高与大小


Posted in Javascript onAugust 04, 2016

问题

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

Javascript 相关文章推荐
理解Javascript_14_函数形式参数与arguments
Oct 20 Javascript
document.createElement()用法及注意事项(ff下不兼容)
Mar 13 Javascript
Jquery Validate 正则表达式实用验证代码大全
Aug 23 Javascript
Javascript实现获取窗口的大小和位置代码分享
Dec 04 Javascript
移动设备web开发首选框架:zeptojs介绍
Jan 29 Javascript
jquery中map函数遍历数组用法实例
May 18 Javascript
使用Javascript写的2048小游戏
Nov 25 Javascript
基于jQuery实现文本框只能输入数字(小数、整数)
Jan 14 Javascript
jQuery的事件预绑定
Dec 05 Javascript
vuejs2.0实现分页组件使用$emit进行事件监听数据传递的方法
Feb 22 Javascript
jQuery获取所有父级元素及同级元素及子元素的方法(推荐)
Jan 21 jQuery
使用Vue.js和Flask来构建一个单页的App的示例
Mar 21 Javascript
JS 数字转换为大写金额的简单实例
Aug 04 #Javascript
js事件冒泡、事件捕获和阻止默认事件详解
Aug 04 #Javascript
使用伪命名空间封装保护独自创建的对象方法
Aug 04 #Javascript
全面解析Angular中$Apply()及$Digest()的区别
Aug 04 #Javascript
window.open不被拦截的简单实现代码(推荐)
Aug 04 #Javascript
js实现多图左右切换功能
Aug 04 #Javascript
window.open打开窗口被拦截的快速解决方法
Aug 04 #Javascript
You might like
在Windows系统上安装PHP运行环境文字教程
2010/07/19 PHP
php导出word格式数据的代码实例
2013/11/25 PHP
ThinkPHP写数组插入与获取最新插入数据ID实例
2014/11/03 PHP
php 静态属性和静态方法区别详解
2017/04/09 PHP
如何利用预加载优化Laravel Model查询详解
2017/08/11 PHP
PHP使用openssl扩展实现加解密方法示例
2020/02/20 PHP
『jQuery』名称冲突使用noConflict方法解决
2013/04/22 Javascript
jquery实现的随机多彩tag标签随机颜色和字号大小效果
2014/03/27 Javascript
DOM基础教程之使用DOM控制表单
2015/01/20 Javascript
Nodejs关于gzip/deflate压缩详解
2015/03/04 NodeJs
深入浅析JavaScript中对事件的三种监听方式
2015/09/29 Javascript
jQuery mobile转换url地址及获取url中目录部分的方法
2015/12/04 Javascript
实例详解jQuery的无new构建
2016/08/02 Javascript
禁用backspace网页回退功能的实现代码
2016/11/15 Javascript
JS实现的表头列头固定页面功能示例
2017/01/10 Javascript
JavaScript中附件预览功能实现详解(推荐)
2017/08/15 Javascript
JS自定义函数实现时间戳转换成date的方法示例
2017/08/27 Javascript
基于js中的存储键值对以及注意事项介绍
2018/03/30 Javascript
javascript 使用sleep函数的常见方法详解
2020/04/26 Javascript
如何利用javascript接收json信息并进行处理
2020/08/06 Javascript
React实现阿里云OSS上传文件的示例
2020/08/10 Javascript
Nest.js环境变量配置与序列化详解
2021/02/21 Javascript
python网络爬虫采集联想词示例
2014/02/11 Python
低版本中Python除法运算小技巧
2015/04/05 Python
virtualenv实现多个版本Python共存
2017/08/21 Python
Python 面向对象之封装、继承、多态操作实例分析
2019/11/21 Python
Python TCP通信客户端服务端代码实例
2019/11/21 Python
俄罗斯三星品牌商店:GalaxyStore
2020/11/04 全球购物
校园安全教育广播稿
2014/02/17 职场文书
房产公证书范本
2014/04/10 职场文书
城市规划应届生推荐信
2014/09/08 职场文书
单位未婚证明范本
2014/11/25 职场文书
英文慰问信
2015/02/14 职场文书
保卫工作个人总结
2015/03/03 职场文书
党员个人承诺书
2015/04/27 职场文书
会计专业2019暑假实习报告
2019/06/21 职场文书