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 相关文章推荐
从sohu弄下来的flash中展示图片的代码
Apr 27 Javascript
javascript 匿名函数的理解(透彻版)
Jan 28 Javascript
推荐10 款 SVG 动画的 JavaScript 库
Mar 24 Javascript
JQuery判断checkbox是否选中及其它复选框操作方法合集
Jun 01 Javascript
xcode中获取js文件的路径方法(推荐)
Nov 05 Javascript
canvas的神奇用法
Feb 03 Javascript
vue2.5.2使用http请求获取静态json数据的实例代码
Feb 27 Javascript
JavaScript+H5实现微信摇一摇功能
May 23 Javascript
JS实现区分中英文并统计字符个数的方法示例
Jun 09 Javascript
Three.JS实现三维场景
Dec 30 Javascript
vue语法自动转typescript(解放双手)
Sep 18 Javascript
JavaScript对象属性操作实例解析
Feb 04 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
PHP中SESSION使用中的一点经验总结
2012/03/30 PHP
thinkphp3查询mssql数据库乱码解决方法分享
2014/02/11 PHP
php防止网站被刷新的方法汇总
2014/12/01 PHP
PHP获取文件夹大小函数用法实例
2015/07/01 PHP
PHP开启目录引索+fancyindex漂亮目录浏览带搜索功能
2019/09/23 PHP
php判断目录存在的简单方法
2019/09/26 PHP
js 数组操作代码集锦
2009/04/28 Javascript
JQuery 国际象棋棋盘 实现代码
2009/06/26 Javascript
Prototype Date对象 学习
2009/07/12 Javascript
JS中批量给元素绑定事件过程中的相关问题使用闭包解决
2013/04/15 Javascript
php和js对数据库图片进行等比缩放示例
2014/04/28 Javascript
JavaScript实现网站访问次数统计代码
2015/08/12 Javascript
浅谈如何实现easyui的datebox格式化
2016/06/12 Javascript
对jQuary选择器的全面总结
2016/06/20 Javascript
Node.js连接MongoDB数据库产生的问题
2017/02/08 Javascript
ES6使用let命令更简单的实现块级作用域实例分析
2017/03/31 Javascript
JS实现将链接生成二维码并转为图片的方法
2018/03/17 Javascript
layui从数据库中获取复选框的值并默认选中方法
2018/08/15 Javascript
手把手教你 CKEDITOR 4 扩展插件制作
2019/06/18 Javascript
python实现判断数组是否包含指定元素的方法
2015/07/15 Python
Pycharm2017版本设置启动时默认自动打开项目的方法
2018/10/29 Python
python多线程http压力测试脚本
2019/06/25 Python
Pandas+Matplotlib 箱式图异常值分析示例
2019/12/09 Python
python  ceiling divide 除法向上取整(或小数向上取整)的实例
2019/12/27 Python
Django之form组件自动校验数据实现
2020/01/14 Python
如何用python实现一个HTTP连接池
2021/01/14 Python
可自定义箭头样式的CSS3气泡提示框
2016/03/16 HTML / CSS
美国南加州的原创极限运动潮牌:Vans(范斯)
2016/08/05 全球购物
意大利制造的西装、衬衫和针对男士量身定制的服装:Lanieri
2018/04/08 全球购物
链表面试题-一个链表的结点结构
2015/05/04 面试题
招商业务员岗位职责
2013/12/16 职场文书
四风问题党员个人整改措施
2014/10/27 职场文书
2014年客服工作总结与计划
2014/12/09 职场文书
办公用品质量保证书
2015/05/11 职场文书
军训决心书范文
2015/09/22 职场文书
大学生如何逃脱“毕业季创业队即散伙”魔咒?
2019/08/19 职场文书