• jquery上传图片获取像素


    问题

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

  • 相关阅读:
    hdu1561--树形dp<依赖背包>
    hdu--1520--树形dp<写起来就是深搜啊>-<滚动数组优化>
    hdu--1595-另类最短路
    hdu--1599--最小环<会加深你对floyd的理解>
    hdu--1851--尼姆博弈&&巴什博弈<也有人用了sg可惜我还不懂>
    hdu--4920--原来一直写了速度慢的矩阵乘法
    hdu--4912--终于解脱了
    hdu--4947--我太天真了
    hdu--2576--高中数学..
    hdu--2579--第二次与女孩的约会
  • 原文地址:https://www.cnblogs.com/kimc1112/p/8891243.html
Copyright © 2020-2023  润新知