上传图片的预览

本文介绍如何使用JavaScript将本地文件转换为Base64字符串或URL,以便在网页中显示图片。提供了两种方法:一是利用URL.createObjectURL()创建本地文件的URL,二是使用FileReader的readAsDataURL()方法读取文件并转换为Base64格式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

两种方法

  1. URL.createObjectURL(obj);

这个函数(window的方法)创建出路径,浏览器能通过原生接口访问本地文件的路径,其中window可以省略,参数为需要创建路径的对象(file对象或者Blob对象);

var imgUrl = URL.createObjectURL( this.files[0] ); //生成本地路径图片
document.querySelector('img').src = imgUrl ;
URL.revokeObjectURL(_file); // 释放这个url
  1. 用FileReader的readAsDataURL方法
var reader = new FileReader();
reader.readAsDataURL(_file);
reader.onload = function(){
    console.log(reader.result); //生成base64格式图片
};

具体写法案例:

<body>
    <input type="file" name="imgfile" id="imgfile">
    <script>
        document.getElementById('imgfile').onchange = function(){
            console.log(this.files[0])
            reads(this.files[0]);
        }
        function reads(_file){
          //var imgUrl = URL.createObjectURL( _file );
		  //document.querySelector('img').src = imgUrl ;
		  //URL.revokeObjectURL(_file); 
		
          var reader = new FileReader();
          reader.readAsDataURL(_file);
          reader.onload = function(){
              document.getElementById("img").src= reader.result;
          };
        }
    </script>
</body>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值