php filereader,FileReader API的使用

这次给大家带来FileReader API的使用,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 来访问。

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

c4a4c35dca7a60760d91528586864e93.png

文件阅读器组件

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

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

62e3e32b9cc141e7c7feb124a5281ded.png

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

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

添加样式

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

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

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

Read File

.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;

}

}

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

19bec5ae65a9b400fbc717379a05a05a.png

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值