纯前端读写文件?

简介: 纯前端读写文件?

事情是这样的我发现vscode在线版居然可以打开文件目录和文件,还能保存文件。

兼容性一般 目前 谷歌edgeOpera 支持 其他均不支持

https://vscode.dev/

查了一下MDN 发现增加新的API 了

https://developer.mozilla.org/zh-CN/docs/Web/API/Window/showDirectoryPicker

showDirectoryPicker

这是一项实验性技术 未来版本可能会发生变化 作用就是显示一个目录选择器 返回Promise

const btn = document.getElementById("btn");
btn.addEventListener("click", () => {
showDirectoryPicker().then(async (dir) => {
  const recursion = async (dir) => {
    if (dir.entries) {
      const dirs = dir.entries();
      for await (let item of dirs) {
        item.forEach((file) => {
          if (typeof file === "string") {
            const p = document.createElement("p");
            p.innerText = file;
            p.style.marginLeft = "10px";
            document.querySelector(".result").appendChild(p);
          } else {
            recursion(file);
          }
        });
      }
    }
  };
  recursion(dir);
 });
});

获取选中目录下所有的文件平铺展开

showOpenFilePicker

showOpenFilePicker这个API 返回用户所选的文件 不是目录默认单选 可设置 multiple 多选

btn.addEventListener("click", () => {
        showOpenFilePicker().then(async (file) => {
          console.log(await file[0].getFile());
        });
      });

可以调用getFile 返回 File对象 就跟 input file 返回的对象一样了可以操作了。

showSaveFilePicker

showSaveFilePicker 这个API可以写入一个文件 返回promise

showSaveFilePicker().then(file=>{
  console.log(file);
})

目录
相关文章
|
6天前
|
存储 程序员 C语言
C文件读写
【2月更文挑战第14天】C文件读写。
15 1
|
6天前
|
存储 Windows
学习文件和文件操作
要将数据进⾏持久化的保存,我们可以使用文件。
15 0
|
6天前
|
存储 程序员 编译器
|
7月前
|
存储 C语言
C 文件读写
C 文件读写。
25 0
|
6天前
|
存储 移动开发 Linux
C++017-C++文件读写应用
C++017-C++文件读写应用
|
6月前
|
存储 C++ iOS开发
70 C++ - 文件读写
70 C++ - 文件读写
37 0
|
自然语言处理 C++ 知识图谱
文件操作
文件操作
53 0
|
存储 编译器 C语言
【学习笔记之我要C】文件操作
【学习笔记之我要C】文件操作
58 0
【学习笔记之我要C】文件操作
|
API C语言 C++
C++文件操作的5种方式
C++文件操作的5种方式
132 1
|
缓存 数据格式
文件读写
文件读写
76 0