FileReader如何实现文件阅读器

这次给大家带来FileReader如何实现文件阅读器,FileReader实现文件阅读器的注意事项有哪些,下面就是实战案例,一起来看一下。

有时候我们需要从文件中读取数据。在以前,你需要将其发送到服务器,然后返回所需的数据。问题是,现在我们还可以使用 FileReader API 直接访问浏览器中的文件。

如果我们只是想读取一个文本文件,以便在UI级别上做一些无关紧要的事情,那么就不需要将文件发送到服务器。下面的示例将实现从一个文件中读取相关的数据填充到一个 textarea 中。

FileReader API

FileReader API提供了一个很好的接口,可以使用文本或Blob对象类型以不同的方式读取数据。

FileReader 实例有一个 readAsText 方法,我们可以使用它来读取文件作为文本:

const reader = new FileReader();reader.readAsText(file);

登录后复制

由于FileReader API是异步的,因此它公开了一些我们可以用来获得它的状态的事件。特别是,当读取文件时,我们需要 onload 事件来访问数据:

const reader = new FileReader();reader.onload = e => console.log(e.target.result);reader.readAsText(file);

登录后复制

正如你所看到的,文本数据可以通过 e.target.result 来访问。

到目前为止,浏览器对其支持情况如下:

FileReader如何实现文件阅读器

文件阅读器组件

前面的代码已经读取了一个文件,但是我们仍然要给它一个 file 对象。为此,我们必需使用 的HTML标记,这将触发一个 change 事件,然后通过 e.target.files 访问该文件。

让我们创建一个 FileReader 组件,将其组合在一起:

 Vue.component('file-reader',{ template: '#fileReader', methods: {  loadTextFromFile: function (e) {   const file = e.target.files[0]   const reader = new FileReader()   reader.onload = e => this.$emit('load', e.target.result)   reader.readAsText(file)  } }})

登录后复制

组件监听 load 事件,以便父组件能够处理数据。

使用组件

把新创建的 file-reader 组件挂载到 #app 的 p 元素下,来演示我们的组件:

let app = new Vue({ el: '#app', data () { return { text: '' } }})

登录后复制

我们需要在 data 中添加一个 text 属性,并使用 v-model 将其绑定到 textarea 上。最后,我们将捕获 @load 事件,并通过 $event 将 text 属性设置为有效的加载事件。

这个时候你看到的效果如下:

FileReader如何实现文件阅读器

其实到现在,功能已经有了,在你的浏览器像下图这样操作,你就可以看到效果了:

FileReader如何实现文件阅读器

特别提醒:我尝试了几种文件格式,对于图片、PDF等文件格式加载会乱码,但加载 .md 或者 .doc 之类的文件,对应的内容能正常的显示在 textarea 中。

添加样式

如果你阅读到这里的话,你应该看到了效果。长得很丑(事实上没有任何的样式效果)。接下来添加一些样式,让其看起来好看一些。

在每个浏览器中, 的渲染效果是不一样的。如果我们想要一个相同的渲染效果,就需要有一个自定义的样式。那么可以将 input 隐藏,并使用

要隐藏 input ,可以使用 opacity:0 或使用 display:block , visibility:hidden 让其具有可访问性。我们还需要使用 position 和 z-index 两属性,以便把它放在 label 后面:

 .file-reader { position: relative; overflow: hidden; display: inline-block; border: 2px solid black; border-radius: 5px; padding: 8px 12px; cursor: pointer; input {  position: absolute;  top: 0;  left: 0;  z-index: -1;  opacity: 0; }}

登录后复制

当然,为了好看一些,你还可以给其他元素添加一些样式。最终你看到的效果如下:

FileReader如何实现文件阅读器

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

遍历DOM文档树有哪些方法

Vue如何调用第三方验证码

以上就是FileReader如何实现文件阅读器的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2765601.html

(0)
上一篇 2025年3月8日 10:59:15
下一篇 2025年3月2日 22:12:54

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Vue引用外部样式文件步骤详解

    这次给大家带来Vue引用外部样式文件步骤详解,Vue引用外部样式文件的注意事项有哪些,下面就是实战案例,一起来看一下。 问题描述 对于.vue的文件来说,也是由结构、行为、样式三部分组成,在样式部分有个scoped的属性,也就是当前页面有效…

    2025年3月8日
    200
  • Vue封装上传文件组件步骤详解(附代码)

    这次给大家带来Vue封装上传文件组件步骤详解(附代码),Vue封装上传文件组件的注意事项有哪些,下面就是实战案例,一起来看一下。 一、之前遇到的一些问题 项目中多出有上传文件的需求,使用现有的UI框架实现的过程中,不知道什么原因,总会有一些…

    编程技术 2025年3月8日
    200
  • 不重启Vim重新加载 .vimrc 文件如何实现

    这次给大家带来不重启Vim重新加载 .vimrc 文件如何实现,不重启Vim重新加载 .vimrc 文件如何实现的注意事项有哪些,下面就是实战案例,一起来看一下。 我是一位新的 Vim 编辑器用户。我通常使用 :vs ~/.vimrc 来加…

    编程技术 2025年3月8日
    200
  • vue文件树组件使用技巧

    这次给大家带来vue文件树组件使用技巧,vue文件树组件使用的注意事项有哪些,下面就是实战案例,一起来看一下。 本文主要是分析vue官方仓库里的文件树组件[vue github] demo可以查看 https://codepen.io/sh…

    编程技术 2025年3月8日
    200
  • HS实现txt文件上传预览

    这次给大家带来HS实现txt文件上传预览,HS实现txt文件上传预览的注意事项有哪些,下面就是实战案例,一起来看一下。 今天做项目刚好碰到这个记录一下。因为是简单的txt文件,只涉及文本,如果需要涉及图片预览就需要使用papaparse和j…

    2025年3月8日
    200
  • Vue封装轻量级上传文件组件步骤详解

    这次给大家带来Vue封装轻量级上传文件组件步骤详解,Vue封装轻量级上传文件组件的注意事项有哪些,下面就是实战案例,一起来看一下。 一、之前遇到的一些问题 项目中多出有上传文件的需求,使用现有的UI框架实现的过程中,不知道什么原因,总会有一…

    编程技术 2025年3月8日
    200
  • vue实现图片与文件上传步骤详解

    这次给大家带来vue实现图片与文件上传步骤详解,vue实现图片与文件上传的注意事项有哪些,下面就是实战案例,一起来看一下。 html页面 //注意不能带括号 登录后复制 js代码 methods: {//上传图片onUpload(e){ v…

    2025年3月8日
    200
  • Vue单页应用引用样式文件步骤详解

    这次给大家带来Vue单页应用引用样式文件步骤详解,Vue单页应用引用样式文件的注意事项有哪些,下面就是实战案例,一起来看一下。 问题描述 对于.vue的文件来说,也是由结构、行为、样式三部分组成,在样式部分有个scoped的属性,也就是当前…

    2025年3月8日
    200
  • 如何使用vue文件树组件

    这次给大家带来如何使用vue文件树组件,使用vue文件树组件的注意事项有哪些,下面就是实战案例,一起来看一下。 首先是html模板: //显示文件名 {{model.name}} //若是文件夹的话则显示[+]来控制文件夹的开关闭合 [{{…

    编程技术 2025年3月8日
    200
  • 使用JS进行文件拖拽

    这次给大家带来使用JS进行文件拖拽,使用JS进行文件拖拽的注意事项有哪些,下面就是实战案例,一起来看一下。 1.效果图: 2.源码 #p1 { width: 350px; height: 70px; padding: 10px; borde…

    2025年3月8日
    200

发表回复

登录后才能评论