用JS怎么制作上传图片的功能,原理及方法是什么
Admin 2022-06-18 群英技术资讯
前端上传图片的原理是:运用input type=“file”的标签获取图片,再使用FileReader这个对象 new 一个实例,通过这个对象的readAsDataURL()方法读取file标签获取的图片并转换为base64格式,完成之后通过ajax之类的方式传到后台。
HTML
需要一个input type="file" 的标签 如果需要预览的话可以再加一个img标签
<div class="warp"> <div class="warp-content">点击上传</div> <input type="file" id="file" /> </div> <img src="" />
JS
一、图片上传需要检测上传的图片是否变化,所以这里选择js的onchange事件.先获取input,img的dom元素,在input type=‘file'的demo元素下,有一个files属性,里面是我们上传的文件信息,打印一下,就可以看到上传文件的名字,类型等信息。
var file = document.getElementById('file'); var image = document.querySelector("img"); file.onchange = function() { var fileData = this.files[0];//这是我们上传的文件 }
二、然后运用 FileReader 这个对象,FileReader主要用于将文件内容读入内存,通过一系列异步接口,可以在主线程中访问本地文件。使用FileReader对象,web应用程序可以异步的读取存储在用户计算机上的文件(或者原始数据缓冲)内容,可以使用File对象或者Blob对象来指定所要处理的文件或数据。这里用到了里面的 readAsDataURL 这个方法,它能把文件用base64格式读出。
使用方法
var reader = new FileReader(); reader.readAsDataURL(fileData);//异步读取文件内容,结果用data:url的字符串形式表示 /*当读取操作成功完成时调用*/ reader.onload = function(e) { console.log(e); //查看对象属性里面有个result属性,属性值,是一大串的base64格式的东西,这个就是我们要的图片 console.log(this.result);//取得数据 这里的this指向FileReader()对象的实例reader image.setAttribute("src", this.result)//赋值给img标签让它显示出来 }
FileReader对象的属性和事件
FileReader对象 官方文档
三、第二步操作完成我们就可以上传图片的功能了,用户再使用时我们不能保证用户上传的是什么东西,图片还是视频,需要判断一下上传的文件类型 input type=‘file'的demo元素下,有一个files属性它里面有文件类型的信息,我们可以通过这属性来判断上传文件类型。(reader.onload里面通过this.result可以获得图片的base64格式,把它赋值给一个变量传到后台,这样就完成了一个图片上传)
var file = document.getElementById('file'); var image = document.querySelector("img"); file.onchange = function() { var fileData = this.files[0];//获取到一个FileList对象中的第一个文件(File 对象),是我们上传的文件 var pettern = /^image/; console.info(fileData.type) if (!pettern.test(fileData.type)) { alert("图片格式不正确"); return; } var reader = new FileReader(); reader.readAsDataURL(fileData);//异步读取文件内容,结果用data:url的字符串形式表示 /*当读取操作成功完成时调用*/ reader.onload = function(e) { console.log(e); //查看对象 console.log(this.result);//要的数据 image.setAttribute("src", this.result) } }
全部代码:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <style type="text/css"> .warp { display: inline-block; vertical-align: bottom; position: relative; } .warp-content { border: 1px solid red; width: 150px; height: 150px; line-height: 150px; text-align: center; } input { position: absolute; top: 0; left: 0; border: 1px solid red; width: 150px; height: 150px; opacity: 0; cursor: pointer; } img { width: 300px; height: 300px; border: 1px solid red; margin-top: 50px; vertical-align: bottom; } </style> </head> <body> <div class="fileBox"> <div class="warp"> <div class="warp-content">点击上传</div> <input type="file" id="file" /> </div> <img src="" /> </div> <script type="text/javascript"> var file = document.getElementById('file'); var image = document.querySelector("img"); file.onchange = function() { var fileData = this.files[0];//获取到一个FileList对象中的第一个文件( File 对象),是我们上传的文件 var pettern = /^image/; console.info(fileData.type) if (!pettern.test(fileData.type)) { alert("图片格式不正确"); return; } var reader = new FileReader(); reader.readAsDataURL(fileData);//异步读取文件内容,结果用data:url的字符串形式表示 /*当读取操作成功完成时调用*/ reader.onload = function(e) { console.log(e); //查看对象 console.log(this.result);//要的数据 这里的this指向FileReader()对象的实例reader image.setAttribute("src", this.result) } } </script> </body> </html>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:[email protected]进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要给大家分享vue实现全屏和退出全屏的内容,实现效果如下, vue中默认进来页面的某个div全屏,当退出全屏次数5次,那么就跳转其他页面,这一效果可以应用在线上答题考试中,下面我们就来具体看看怎样做吧。
这篇文章主要介绍了js 数组 fill() 的填充方法,初始化数组的方法,但是初始化数组之后,数组中的每一项元素默认为 empty 空位占位,如何对数组这些空位添加默认的元素,ES6提供了 fill() 方法实现这一操作。本文总结数组 fill() 方法的详细使用,需要的朋友可以参考一下
这篇文章我们主要了解关于vue中router传参方式,本文有示例代码供大家参考,感兴趣的朋友可以了解看看,另外本文还分享了刷新页面数据丢失的解决方法,接下来我们一起了解看看吧。
这篇文章给大家分享的是有关vue动态设置路由的内容,下面介绍了vue动态设置路由权限的思路,具有一定的借鉴价值,因此分享给大家做个参考,感兴趣的朋友可以了解一下。
这篇文章给大家分享一个jQuery相关示例,需求是判断点击了哪个li,这里使用到的方法index()方法,文中示例代码有一定的参考价值,感兴趣的朋友可以了解看看,下面我们一起来学习一下jQuery中判断点击哪个li的方法。
推荐内容
联系我们
24小时售后Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有 茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078