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}`);
    }
 赞
 已采纳


  • 2020-06-02 08:57:12

    clipboard复制成功但是粘贴板是空的

    将文本复制到剪贴板应该不难。配置它不需要几十个步骤,也不需要加载数百KB的js文件 。但最重要的是,它不应该依赖Flash或任何臃肿的框架。这就是clipboard.js存在的原因。

  • 2020-06-04 13:54:21

    vue生成的__ob__: Observer无法解析jsonp

    computed 从vuex获得数据,watch监听数据 然而问题就出现在了监听上,监听不到,给个setTimeOut 1000 就能检测到数据了,不然打印时又数据,用的时候时空的,不知道时什么原因。

  • 2020-06-06 20:22:56

    laravel 接收json串

    在做项目的时候发现 用平时的$request->all() 无法获取到请求值

  • 2020-06-09 08:50:28

    LRU原理以及js实现

    LRU(Least recently used,最近最少使用)算法根据数据的历史访问记录来进行淘汰数据,其核心思想是“如果数据最近被访问过,那么将来被访问的几率也更高”。

  • 2020-06-20 06:31:16

    mac下全局配置adb环境

    不提示“command not found”,而是出现一长串帮助说明,那就证明adb已经配置好了。

  • 2020-06-20 06:31:39

    Android 无线调试手机(WiFi 调试)

    手机需要开启 USB 调试 手机和电脑要在同一个局域网(连接同一个 WiFi) adb connect 连接成功后要拔出 USB 线,不然出现同时连接两个设备的问题 执行命令 ”adb tcpip 6666“ 后可能需要重新开启 USB 调试