【html5】06-文件读取

目录

引言

知识点陈列

  实现代码

 案例-读取图片显示


引言

在HTML5中,我们可以使用FileReader API来读取用户通过<input type="file">元素选择的文件。这个API允许Web应用程序异步地读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用File或Blob对象指定要读取的文件或数据。

知识点陈列

```html```

  ☞  FileReader

         FileReader                接口有3个用来读取文件方法返回结果在result中

  1.          readAsBinaryString    ---将文件读取为二进制编码
  2.          readAsText           ---将文件读取为文本
  3.          readAsDataURL           ---将文件读取为DataURL

 ☞  FileReader 提供的事件模型

  1.      onabort     中断时触发
  2.      onerror     出错时触发
  3.      onload      文件读取成功完成时触发
  4.      onloadend   读取完成触发,无论成功或失败
  5.      onloadstart  读取开始时触发
  6.      onprogress  读取中

适用范围:上传小文件

  实现代码

获取文件:只获取了一个文件

开始读取:创建读取器对象,调用该对象里的方法,将文件读取为xxx格式

读取结果:当文件读取完成之后,才打印文件里的内容

<body>
	<input type="file" name="">
	<script type="text/javascript">
		var input = document.querySelector("input");
// 当文件输入元素的内容改变时(例如用户选择了一个新的文件),这个匿名函数会被调用
		input.onchange = function () {
			//获取到文件
			var file = this.files[0];
			//开始读取,创建读取器
			var reader = new FileReader();
			//开始读取
			reader.readAsText(file);
			//获取读取的结果
			//当文件读取完成后,才可以获取文件信息内容
			reader.onload = function () {
				console.log(reader.result);
			}
		}
	</script>
</body>

当提交了文件之后,在控制台会打印出文件里的内容

 案例-读取图片显示

1完整代码

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>显示图片</title>
</head>
<body>
	   <input type="file">
	   <script type="text/javascript">
	   	
	   		 var file_btn=document.querySelector("input");

	   		 	 file_btn.onchange=function() {

	   		 	 		var file=this.files[0];
	   		 	 		
	   		 	 		//判断后缀名是否合法
	   		 	 
	   		 	 		var filename=file.name.substring(file.name.lastIndexOf("."));

	   		 	 		var imgs=[".png",".jpg","gif",".ico"];

	   		 	 		var flag=false;

	   		 	 		for(var i=0; i<imgs.length; i++) {
	   		 	 			 if(imgs[i]==filename) {
	   		 	 			 	 flag=true;
	   		 	 			 	 break;
	   		 	 			 }
	   		 	 		}

	   		 	 		if(flag) {
	   		 	 			
	   		 	 			 var reader=new FileReader();
	   		 	 			 	 reader.readAsDataURL(file);

	   		 	 			 reader.onload=function() {
	   		 	 			 	  var img=document.createElement("img");
	   		 	 			 	  	  img.src=reader.result;
	   		 	 			 	  document.body.appendChild(img);
	   		 	 			 }

	   		 	 		}else {
	   		 	 			alert("文件类型不正确,请重新选择");
	   		 	 		}

	   		 	 }

	   </script>
</body>
</html>

2 效果说明

点击上传对应正确格式的图片,会直接渲染在页面上,

每次只能上传一张图片,可以多次上传,图片不会被覆盖

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mikuc

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值