input上传图片,获取图片上传尺寸

2020-01-04 08:14:56

并没有直接的办法获取图片上传尺寸,需要对图片进行加载等处理

我觉得还可以改变一下逻辑,可以都预览,等提交等时候检测一下大小,不让提交通过不就完了。

我的原理就是和上传预览差不多,简单说下:

  1. onchange触发,获取当前file对象(这里可以获取图片的大小、类型、修改时间等)

  2. reader去读取文件

  3. 塞到页面,获取图片的宽高

  4. 移出图片节点

代码,见以下:

<input type="file" onchange="getImgInfo(this,getImgInfoCb)"/>
function getImgInfo(ev,fnCallBack){        var oFile=ev.files[0];        var reader=new FileReader();

        reader.onload=function(){            // 也可以用 window.URL.createObjectURL(this.result)
            var oImg=new Image();
            oImg.src=this.result;            document.body.appendChild(oImg);
            
            oImg.onload=function(){                var imgWidth=oImg.offsetWidth;                var imgHeight=oImg.offsetWidth;
                fnCallBack && fnCallBack({                    width:imgWidth,                    height:imgHeight
                })                document.body.removeChild(oImg);
            };
        };
        reader.readAsDataURL(oFile);
    }    function getImgInfoCb(json){        console.log(`width:${json.width} , height:${json.height}`);
    }
 赞
 已采纳


  • 2019-02-25 10:05:41

    Android Socket连接(模拟心跳包,断线重连,发送数据等)

    因为是要保证全局只能有一个连接,而且我们还需要在不同的Activity中发指令,因此肯定不能在需要发指令的界面中都去连接socket,这样一来不好管理,性能也不好,重复代码也会比较多,所以想了一下还是把socket放到service中比较好,发指令功能都放在service中即可。

  • 2019-02-28 15:54:24

    HTTP协议缓存策略深入详解之ETAG妙用

      HTTP协议规格说明定义ETag为“被请求变量的实体值” 。另一种说法是,ETag是一个可以与Web资源关联的记号(token)。典型的Web资源可以一个Web页,但也可能是JSON或XML文档。服务器单独负责判断记号是什么及其含义,并在HTTP响应头中将其传送到客户端。

  • 2019-02-28 16:46:26

    android获取视频、图片时添加防盗链

    使用HTTP协议时,可以利用头信息中的Referer做防盗链。 我们在一些网站的网页里访问图片的时候,在图片本站是可以正常看到的,但在外头就不能看到了,这是因为在http的header信息中的referer元素。

  • 2019-03-02 11:29:17

    MySQL学习之索引顺序

    这个问题比较简单,MySQL本身会对条件和索引进行判断,这样写可以用到索引,没有问题。

  • 2019-03-06 11:24:19

    MySQL查看数据库表容量大小

    本文介绍MySQL查看数据库表容量大小的命令语句,提供完整查询语句及实例,方便大家学习使用。

  • 2019-03-13 09:38:11

    写入MySQL报错超出 max_allowed_packet 的问题

    MySQL会根据配置文件会限制server接受的数据包的大小。如果写入大数据时,因为默认的配置太小,插入和更新操作会因为 max_allowed_packet 参数限制,而导致失败。