Vue文件阅读器组件FileReader API

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

有时候我们需要从文件中读取数据。在以前,你需要将其发送到服务器,然后返回所需的数据。问题是,现在我们还可以使用 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 来访问。

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

Vue文件阅读器组件FileReader API

文件阅读器组件

前面的代码已经读取了一个文件,但是我们仍然要给它一个 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 属性设置为有效的加载事件。

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

Vue文件阅读器组件FileReader API

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

Vue文件阅读器组件FileReader API

特别提醒:我尝试了几种文件格式,对于图片、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; }}

登录后复制

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

Vue文件阅读器组件FileReader API

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

推荐阅读:

react做出按需加载效果

JS同源策略+跨域访问使用详解

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

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

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

(0)
上一篇 2025年3月8日 12:29:35
下一篇 2025年2月27日 12:54:54

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

相关推荐

  • Angular父组件调用子组件步奏详解

    这次给大家带来Angular父组件调用子组件步奏详解,Angular父组件调用子组件的注意事项有哪些,下面就是实战案例,一起来看一下。 组件是一种特殊的指令,使用更简单的配置项来构建基于组件的应用程序架构.这篇文章主要介绍了Angular组…

    2025年3月8日
    200
  • vue全局局部组件使用详解

    这次给大家带来vue全局局部组件使用详解,vue全局局部组件使用的注意事项有哪些,下面就是实战案例,一起来看一下。 —main.js文件 **main.js入口文件的内容**import Vue from ‘vue’import App f…

    编程技术 2025年3月8日
    200
  • vue父组件怎么调用子组件

    这次给大家带来vue父组件怎么调用子组件,vue父组件调用子组件的注意事项有哪些,下面就是实战案例,一起来看一下。 情景:   父组件中引入上传附件的子组件:点击组件可以分别上传对应要求的图片,子组件内部循环可创建多个模块.   父组件传入…

    2025年3月8日
    200
  • jQuery主要API有哪些

    这次给大家带来jQuery主要API有哪些,jQuery主要API使用的注意事项有哪些,下面就是实战案例,一起来看一下。 jquery核心函数 函数 描述jQuery() 这个函数接收一个包含 CSS 选择器的字符串,然后用这个字符串去匹配…

    2025年3月8日
    200
  • 表格排序组件tablesorter使用的步骤详解

    这次给大家带来表格排序组件tablesorter使用的步骤详解,表格排序组件tablesorter使用的注意事项有哪些,下面就是实战案例,一起来看一下。 一、引入文件      登录后复制 效果如图:  二、标准的HTML表格,必须包括th…

    2025年3月8日
    200
  • vue项目中api接口使用详解

    这次给大家带来vue项目中api接口使用详解,vue项目中api接口使用的注意事项有哪些,下面就是实战案例,一起来看一下。 默认vue项目中已经使用vue-cli生成,安装axios,基于element-ui开发,axiosconfig目录…

    编程技术 2025年3月8日
    200
  • vue文件树组件使用(附代码)

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

    编程技术 2025年3月8日
    200
  • vue全局与局部组件使用步骤详解

    这次给大家带来vue全局与局部组件使用步骤详解,vue全局与局部组件使用的注意事项有哪些,下面就是实战案例,一起来看一下。 main.js入口文件的一些常用配置, 在入口文件上定义的public.vue为全局组件,在这里用的是pug模版 .…

    编程技术 2025年3月8日
    200
  • vue常用组件使用详解

    这次给大家带来vue常用组件使用详解,vue常用组件使用的注意事项有哪些,下面就是实战案例,一起来看一下。 项目技术: webpack + vue + element + axois (vue-resource) + less-loader…

    编程技术 2025年3月8日
    200
  • vue组件写法规范

    这次给大家带来vue组件写法规范,vue组件写法规范的注意事项有哪些,下面就是实战案例,一起来看一下。 数据驱动和组件化是vue.js两个最重要的特点。组件化是为了方便代码复用,提高开发效率。常见的vue组件写法有四种,各有特色,适用于不同…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论