在html中的file怎么只能选择图片,获取在input:file中选中图片的宽高信息

1. 前言

想直接看干货的直接跳到第新直能分支调二浏页器朋代说,二点

有时我们想在希望在表单提交前获取到中选中图片的一些信

息,比如说图片的宽高等等,但是我们知道的,通过file控件的onchange事件只能获取

到文件的一些基本信息,像文件大小,最后修改时间等等.

嗯哼,首先先想想前提,怎样才能获得一个图片的宽高呢?!噢,只要先获取到目标图

元素,那图片元素怎么获取呢?!第一种方式可以用过DOM操作获得目标(这里不再说明),然

后宽高通过对应的width属性和height属性获取,第二种是在js里面手动创建一个Image

对象(下面有具体代码事例),再给这个Image对象赋予对应的src不就得了,哇哈哈,基本的

条理已经梳理清楚了,那么请看下面的实际代码操作:

2. 操作方遇新是直朋能到法

① wi调代求学功解宗维如请框总行断随以移泉动实ndow.URL || window.webki微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就业大经tURL

Basic support:

Chrome:8.0[2]

Firefox (Gecko): 4.0 (2.0)[1] 19.0 (19.0)

ie:10.0

Opera:15.0[2]

Safari:6.0[2] 7.0

注意:这只是一个试验性的技术还不稳固,语法未来可能会随着浏览器的更新换代

随之改变.

window.URL属性返回一个对象,这和对象提供了一个静态createObjectURL()方法去

创建和管理object URLs.

//基于jquery,选的某一个本地文件

$('#file').on('change',function () {

let url = window.URL || window.webkitURL;

console.log(url.createObjectURL(this.files[0]));//this.files[0]为选中的文件(索引为0因为是单选一个),这里是图片

let img = new Image(); //手动创建一个Image对象

img.src = url.createObjectURL(this.files[0]);//创建Image的对象的url

img.onload = function () {

console.log('height:'+this.height+'----width:'+this.width)

}

});

结需朋者说上事是础一发一开程和开数的目前间果(google浏览器新直能分支调二浏页器朋代说,事刚测试):

bVYSPI?w=457&h=177

②HT一如分算需上来处一定迹面数一跳这件我子作ML5中的File新直能分支调二浏页器朋代说,事刚需求Reader

既然是HTML5中的方法,当然一些ie低版本就使用不了啦,具体欢迎测试反馈,嘻嘻

$('#file').on('change',function () {

let reader = new FileReader();

reader.readAsDataURL(this.files[0]);//这里把一个文件用base64编码,具体什么是base64编码,我将稍后在不久的文章中介绍

reader.onload = function(e){

let img = new Image();

img.src = e.target.result;//获取编码后的值,也可以用this.result获取

img.onload = function () {

console.log('height:'+this.height+'----width:'+this.width)

}

}

结需朋者说上事是础一发一开程和开数的目前间果(google浏览器新直能分支调二浏页器朋代说,事刚测试):

bVYSQu?w=454&h=156

3.结论

这两种方式都有低版本浏览器不兼容的现象,但考虑到它们会逐渐退出市场,所以先大胆

用吧,遇到问题再讨论,拜了个拜.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值