使用FileReader对象的readAsDataURL方法回显图片

<!DOCTYPE html>
<html>

	<head>
		<meta charset="utf-8" />
		<title>使用FileReader对象的readAsDataURL方法回显图片</title>
		<script type="text/javascript" src="js/jquery-2.1.0.js" ></script>
	</head>
	
<body>
	<script type="text/javascript">  
     function changImg(e){  
        for (var i = 0; i < e.target.files.length; i++) {  
            var file = e.target.files.item(i); 
            //正则表达式判断文件类型是否为图片
            while (!(/^image\/.*$/i.test(file.type))) {              	
                  
                alert('不是图片');
                break;//不是图片 就跳出这一次循环
            }  
            //实例化FileReader 
            var freader = new FileReader(); 
            //FileReader对象的readAsDataURL方法可以将读取到的文件编码成Data URL
            //readAsDataURL方法会使用base-64进行编码
            //编码的资料由data字串开始,后面跟随的是MIME type,然后再加上base64字串,逗号之后就是编码过的图像文件的内容。
            freader.readAsDataURL(file);  
            freader.onload = function(e) { 
            	//更改img的src属性
                $("#myImg").attr("src",e.target.result);  
            }  
        }  
    }  
</script> 

<form action="">  
   <input type="file" name="files" accept="image/*" οnchange="changImg(event)" >
   <img alt="暂无图片" id="myImg"  height="200px",width="200px">  
</form> 
</body>  
 
</html>

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
`readAsDataURL` 是 JavaScript File API 中的一个方法,可用于将文件读取为数据 URL。它可以用于在浏览器中预览图像文件或将文件转换为 base64 编码的字符串。 使用 `readAsDataURL` 方法需要创建一个 `FileReader` 对象,并将要读取的文件传递给它。然后,通过监听 `FileReader` 对象的 `onload` 事件,在事件处理函数中可以获取到读取的数据 URL。 以下是一个简单的示例代码: ```javascript function handleFileSelect(event) { var file = event.target.files[0]; var reader = new FileReader(); reader.onload = function(e) { var dataURL = reader.result; console.log(dataURL); // 在这里可以对数据 URL 进行进一步处理 }; reader.readAsDataURL(file); } var fileInput = document.getElementById('fileInput'); fileInput.addEventListener('change', handleFileSelect, false); ``` 在上面的示例中,我们创建了一个文件输入元素(id 为 "fileInput"),当用户选择文件后,会触发 `change` 事件,然后调用 `handleFileSelect` 函数来处理选中的文件。在 `handleFileSelect` 函数中,我们创建了一个 `FileReader` 对象并将文件传递给它,然后监听 `onload` 事件,在事件处理函数中获取到读取的数据 URL。 请注意,由于安全性限制,浏览器可能会阻止在没有用户交互的情况下自动触发文件选择操作(例如使用 JavaScript)。因此,通常需要通过用户手动选择文件来触发 `handleFileSelect` 函数。 希望这可以回答您的问题!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

ThinkPet

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

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

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

打赏作者

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

抵扣说明:

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

余额充值