js读写本地文件怎么用(前端获取本地文件流)

出于安全和隐私的原因,web应用程序不能直接访问用户设备上的文件。如果需要读取一个或多个本地文件,可以通过使用inputfile和FileReader来实现。在这篇文章中,我们将通过一些例子来看看它是如何工作的。文件操作的流程获取文件由于浏览器中

出于安全和隐私的原因,web 应用程序不能直接访问用户设备上的文件。如果需要读取一个或多个本地文件,可以通过使用input file和FileReader来实现。在这篇文章中,我们将通过一些例子来看看它是如何工作的。

文件操作的流程

获取文件

由于浏览器中的 JS 无法从用户的设备访问本地文件,我们需要为用户提供一种方法来选择一个或多个文件供我们使用。这可以通过文件选择器<input type=’fule’ />来完成。

<input type=\"file\" id=\"fileInput\">

如果想允选择多个文件,可以添加multiple属性:

<input type=\"file\" id=\"fileInput\" multiple>

我们可以通过change事件来监听文件的选择,也可以添加另一个 UI 元素让用户显式地开始对所选文件的处理。

input file 具有一个files属性,该属性是File对象的列表(可能有多个选择的文件)。

js读写本地文件怎么用(前端获取本地文件流)

File对象如下所示:

js读写本地文件怎么用(前端获取本地文件流)

读取文件

读取文件,主要使用的是[FileReader][1]类。

「该对象拥有的属性:」

「FileReader.error」 :只读,一个DOMException,表示在读取文件时发生的错误 。

「FileReader.readyState」:只读 表示 FileReader 状态的数字。取值如下:

常量名值描述EMPTY0还没有加载任何数据LOADING1数据正在被加载DONE2已完成全部的读取请求

「FileReader.result」:只读,文件的内容。该属性仅在读取操作完成后才有效,数据的格式取决于使用哪个方法来启动读取操作。

「该对象拥有的方法:」

readAsText(file, encoding):以纯文本形式读取文件,读取到的文本保存在result属性中。第二个参数代表编码格式。

readAsDataUrl(file):读取文件并且将文件以数据URI的形式保存在result属性中。

readAsBinaryString(file):读取文件并且把文件以字符串保存在result属性中。

readAsArrayBuffer(file):读取文件并且将一个包含文件内容的ArrayBuffer保存咋result属性中。

FileReader.abort():中止读取操作。在返回时,readyState属性为DONE。

「文件读取的过程是异步操作,在这个过程中提供了三个事件:progress、error、load事件。」

progress:每隔50ms左右,会触发一次progress事件。

error:在无法读取到文件信息的条件下触发。

load:在成功加载后就会触发。

在下面的示例中,我们将使用readAsText和readAsDataURL方法来显示文本和图像文件的内容。

例一:读取文本文件

为了将文件内容显示为文本,change需要重写一下:

js读写本地文件怎么用(前端获取本地文件流)

首先,我们要确保有一个可以读取的文件。如果用户取消或以其他方式关闭文件选择对话框而不选择文件,我们就没有什么要读取和退出函数。

然后我们继续创建一个FileReader。reader的工作是异步的,以避免阻塞主线程和 UI 更新,这在读取大文件(如视频)时非常重要。

reader发出一个’load’事件(例如,类似于Image对象),告诉我们的文件已经读取完毕。

reader将文件内容保存在其result属性中。此属性中的数据取决于我们使用的读取文件的方法。在我们的示例中,我们使用readAsText方法读取文件,因此result将是一个文本字符串。

例二:显示本地选择的图片

如果我们想要显示图像,将文件读取为字符串并不是很有用。FileReader有一个readAsDataURL方法,可以将文件读入一个编码的字符串,该字符串可以用作<img>元素的源。本例的代码与前面的代码基本相同,区别是我们使用readAsDataURL读取文件并将结果显示为图像:

js读写本地文件怎么用(前端获取本地文件流)

总结

1)由于安全和隐私的原因,JavaScript 不能直接访问本地文件。

2)可以通过 input 类型为 file 来选择文件,并对文件进行处理。

3) file input 具有带有所选文件的files属性。

4) 我们可以使用FileReader来访问所选文件的内容。

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

(5)
nan
上一篇 2021-08-29
下一篇 2021-08-29

相关推荐

  • JAVA字符串怎么替换指定字符串

    可以使用Java中的replace()方法来替换指定字符串。replace()方法接收两个参数,第一个参数是要被替换的字符串,第二个参数是用来替换的新字符串。例如:String str = “Hello World!”;String newStr = str.replace(“World”, “Java”);System.out.println(newStr);输出结果为:Hello J

    2024-01-18
    0
  • matlab怎么读取dataset中的数据

    要读取dataset中的数据,可以使用MATLAB中的readtable函数或者直接访问dataset的属性。以下是两种方法:使用readtable函数读取dataset中的数据:% 创建一个datasetdata = dataset({'John'; 'Alice'; 'Bob'}, 'VarNames', {&#

    2024-04-20
    0
  • 青岛己强电商有限公司(青岛电子商务)

    “双11”零点“决战”,海信官宣55秒破亿的骄人战绩,日日顺物流智能仓瞬间开启“智慧大脑”的超强算力,即墨移风店镇和胶州花园村等“淘宝村”的村民们忙得不亦乐乎,将打包的皮鞋、假睫毛、服装发往全国各地……即使没有诞生全国性的电商巨头,但有制

    2021-12-12
    0
  • 如何在服务器上开设虚拟主机空间(怎样架设虚拟服务器)

    如何在服务器上开设虚拟主机空间,怎样架设虚拟服务器内容导航:怎样选择免备案虚拟主机空间影子系统和虚拟机是一回事吗什么影子系统或虚拟机好怎么样设置虚拟的主机虚拟主机空间怎么注册一、怎样选择免备案虚拟主机空间免备案的主机,国内主要是香港比较多,其次美国,韩国等等。可以根据网站面向的用户所在地选择,一般网站速度和稳定性会比较好。

    2022-05-01
    0
  • winform如何自定义控件

    在WinForms中自定义控件通常涉及以下步骤:创建自定义控件类:创建一个继承自现有控件(如Control或Panel)的新类,该类将作为自定义控件的基类。添加自定义控件的属性和方法:在自定义控件类中添加需要的属性和方法,以实现控件的特定功能。重写控件的绘制方法:在自定义控件类中重写OnPaint方法,以实现控件的绘制逻辑。处理控件的事件:在自定义控件类中添加需要处理的事件的处理逻辑,以实现控件的

    2024-04-09
    0
  • 数据库怎么导出大表到服务器

    要将数据库中的大表导出到服务器,可以使用数据库管理工具或命令行工具来完成这个操作。以下是一种常用的方法:使用数据库管理工具(如MySQL Workbench、Navicat等)连接到数据库服务器,并选择要导出的数据库。执行SQL查询语句来导出大表的数据,可以使用SELECT语句加上INTO OUTFILE命令来将数据导出到服务器上的文件中。例如:SELECT * INTO OUTFILE &#x

    2024-04-07
    0

发表回复

登录后才能评论