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


  • 2018-11-01 22:08:19

    Android Toolbar左、中、右对齐

    默认的Android Toolbar中添加子元素view是从左到右依次添加。需要注意的是,Android Toolbar为自身的NavigationIcon(app:navigationIcon)最靠右,Logo(app:logo)紧接NavigationIcon、Title(app:title)接续Logo、保留了默认的位置(从左边到右)。这些Android Toolbar保留的系统设置字段将挤压开发者自己安放在Toolbar中的子view,如图所示:

  • 2018-11-06 06:42:59

    XUtils3框架数据库的基本使用方法

    今天给大家带来数据库模块的讲解,现在主流的ORM框架很多,比如OrmLite,GreenDao,Active Android,Realm等等,这些框架每个都有自己的优点和缺点,大家完全可以根据自己项目的实际需求进行选择,下面开始进入今天的数据库模块的介绍。

  • 2018-11-17 21:05:48

    Android ANR发生的原因总结和解决办法

    ANR的全称是application not responding,是指应用程序未响应,Android系统对于一些事件需要在一定的时间范围内完成,如果超过预定时间能未能得到有效响应或者响应时间过长,都会造成ANR。一般地,这时往往会弹出一个提示框,告知用户当前xxx未响应,用户可选择继续等待或者Force Close。