js实现图片预览的几种方式

   考虑到用户体验, 网页的图片上传数据库前,先预览是很有必要的一个步骤,第一可以给用户带来安全感,第二防止图片文件有问题而提交到数据库,占用存储资源。

那么要实现预览有两种方式:一种是用window.URL.createObjectURl方法对选择的图片数据(图片数据可以勉强理解为input的value)生成一个blob对象路径,第二种是用获取 FileReader读取器。

那么无论那种方法,首先都得得到文件数据,获得文件数据是从files集合中获取。

方式一:

代码如下:

<input type=file id="inp">

<script>

   inp.οnchange=function(){

        var file=this.files[0]   // 获取input上传的图片数据;

        var img=new Image()  ;

        url=window.URL.createObjectURL(file)  // 得到bolb对象路径,可当成普通的文件路径一样使用,赋值给src;

        img.src=url;

        //其实也可一句代码搞定,不需要声明那么多变量;img.scr=window.URL.cteateObejectURL(this.files[0]) ;

        然后把img添加到页面就实现预览了

   }

<script>


方式二:

用FileRader对像读取文件.可分为四步;1、创建FileReader对像;2、调用readAsDataURL方法读取文件;3、调用onload事件监听,我们一需要拿到完整的数据,但我们又不知道文件何时读完?,所以需要第三步监听;4、通过FileRader对像r的result属性拿到读取结果。

代码如下:

<input type=file id="inp">

<input type=file id="inp">

<script>

inp.οnchange=function(){

       var read=new FileReader() // 创建FileReader对像;

  read.readAsDataURL(this.files[0])  // 调用readAsDataURL方法读取文件;

           read.οnlοad=function(){

                    url=read.result  // 拿到读取结果;

                    var img=new Image();

                    img.src=url;

                    div.appendChild(img);
  }
   }

OK 到这就完了。。。。。。。。。。。。。。。











  • 7
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

那些年少的伤寂静微凉

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

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

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

打赏作者

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

抵扣说明:

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

余额充值