使用File System Access API 让浏览器可以操作文件

使用File System Access API 让浏览器可以操作文件

在早期我们开始学习前端三件套时,经常会听到这样的说法:浏览器是一个沙盒,它不允许我们操作本地文件,但是现在这个说法已经不再适用了,因为我们可以使用 File System Access API 来实现这个功能。

1、简介

File System Access API 是一项 Web API,允许 Web 应用程序从用户设备的本地文件系统中读取和写入文件。
它提供了一种简单且安全的方法,让用户在不离开 Web 应用的情况下,从本地文件系统中操作文件。
这项 API 为 Web 应用程序提供了更多的灵活性和功能,使其更接近于本地应用程序的体验。

2、实际操作

<html>
<head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<button id="choose" >选择文件</button>
</body>
<script>
document.getElementById('choose').onclick= async function(){
	/**
	 * 打开一个文件
	 */
	var [fileHandle] = await window.showOpenFilePicker();
	/**
	 * 选择目录
	 */
    // var [fileHandle] = await window.showDirectoryPicker();
	//获取文件
	const file = await fileHandle.getFile();
	console.log(file);	
	
	//判断文件类型
	if (fileHandle.kind === 'file') {
	   console.log('this is file');
	} else if (fileHandle.kind === 'directory'){
		console.log('this is directory');
		return;
	}
	
	//读取文件内容
    var reader = new FileReader();  
	reader.onload = function() {  
		console.log( this.result);   
	}  
	reader.readAsText(file);  
		
	//创建写文件内容
    const writable = await fileHandle.createWritable();
	
	//写入内容到文件
    await writable.write("this david wirter file content:"+new Date().getTime());
	//关闭写入操作,否则内容不会写入到文件
    await writable.close();
	
	
	/**
	 * 保存文件
	 */
	 window
	    .showSaveFilePicker({
	      suggestedName: '1.txt', //filename 保存文件名 '1.txt'
	    })
	    .then(async (writeHandle) => {
	      const writableStream = await writeHandle.createWritable();
	      await writableStream.write(file); //file 文件对象
	      await writableStream.close();
	      console.log(`保存成功: ${writeHandle.name}`);
	    })
	    .catch((err) => {
	      console.error("写入失败: ", err);
	    });
			
}
 
</script>
</html>

3、方法列表

FileSystemFileHandle继承自FileSystemHandle,它是一个代表文件系统中的文件或目录的对象。

FileSystemHandle提供了一些方法来获取和操作文件系统中的文件或目录,例如:

kind:返回一个字符串,用于表示文件或目录;
name:返回一个字符串,用于表示文件或目录的名称;
isSameEntry:返回一个boolean值,用于表示两个文件或目录是否相同;
queryPermission:返回一个Promise对象,用于查询文件或目录的权限;
requestPermission:返回一个Promise对象,用于请求文件或目录的权限;
remove:返回一个Promise对象,用于删除文件或目录;
我们可以通过kind属性来判断当前的FileSystemHandle对象是文件还是目录。

FileSystemDirectoryHandle对象是一个代表文件系统中的目录的对象,它提供了一些方法来获取和操作目录。
FileSystemDirectoryHandle提供的方法就比较多了,例如:
entries:返回一个AsyncIterable对象,用于获取目录中的所有文件和目录;
keys:返回一个AsyncIterable对象,用于获取目录中的所有文件和目录的名称;
values:返回一个AsyncIterable对象,用于获取目录中的所有文件和目录的FileSystemHandle对象;
getFileHandle:返回一个Promise对象,用于获取目录中的文件;
getDirectoryHandle:返回一个Promise对象,用于获取目录中的目录;
removeEntry:返回一个Promise对象,用于删除目录中的文件或目录;
resolve:返回一个Promise对象,用于获取目录中的文件或目录;

4、兼容性

在这里插入图片描述
在这里插入图片描述

5、注意事项

在这里插入图片描述
目前这个api只能在本地玩玩,千万别上到生产环境中,这个api对浏览器有要求,网络协议还必须使用https,如果生产环境没有上https,千万别使用。

6、参考地址

参考地址

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阳关的美好

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值