这篇文章主要介绍了JS中读取文件的方法,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:申请域名、虚拟空间、营销软件、网站建设、代县网站维护、网站推广。因为JavaScript中的Web API有了新的方法File API,所以我们在浏览器上读取文件并处理数据更加方便而且不需要使用到后端服务器。
FileReader就是从一个文件中读取数据并存储在一个JavaScript变量中,它与XMLHttpRequest含义差不多,都是从一个外部资源加载数据而且读操作是异步的,这样的好处是不会使浏览器堵塞。它读取操作的方法有多种多样的,例如以下几种方法
(1)readAsText() – 以纯文本的形式返回文件内容
该readAsText()方法可用于读取文本文件。该方法有两个参数。第一个参数是用于File或Blob要被读取的对象。第二个参数用于指定文件的编码。第二个参数是可选的。如果未指定,UTF-8则默认采用编码。在设置中需要在文件加载完成后设置一个事件监听器。onload调用事件时,我们可以检查result属性FileReader所获取文件的内容。
<input type="file" id="file" /> <script type="text/javascript"> var file=document.getElementById("file"); var reader = new FileReader(); reader.onload=function(e){ var text=reader.result; } reader.readAsText(file); </script>
(2)readAsArrayBuffer() 方法
该方法将读取一个Blob或一个File对象并生成一个ArrayBuffer。当读取操作完成时,readyState 变成 done(已完成),并触发 loadend 事件,同时 result 属性中将包含一个 ArrayBuffer 对象用以表示所读取文件的数据,ArrayBuffer 是固定长度的二进制数据缓冲区。在操作文件时比如将JPEG图像转换为PNG
<script type="text/javascript"> var file=document.getElementById("file"); var reader = new FileReader(); reader.onload=function(e){ var readAsArrayBuffer=reader.result; } reader.readAsArrayBuffer(file); </script>
(3)readAsDataURL() 使用数据URL的形式返回文件内容
该方法接受File或Blob生成数据URL,这基本上是文件数据的base64编码字符串可以将此数据URL用于设置src图像属性等内容
<script type="text/javascript"> var file=document.getElementById("file"); var reader = new FileReader(); reader.onload=function(e){ var dataURL = reader.result; } reader.readAsDataURL(file); </script>
上面的三种方法在使用过程中要在开始读取之前,必须监听load事件,而event.target.result是返回读取的结果。
感谢你能够认真阅读完这篇文章,希望小编分享JS中读取文件的方法内容对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,遇到问题就找创新互联,详细的解决方法等着你来学习!
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
本文题目:JS中读取文件的方法-创新互联
URL标题:https://www.cdcxhl.com/article36/csgopg.html
成都网站建设公司_创新互联,为您提供定制开发、商城网站、标签优化、网站策划、电子商务、网站收录
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联