亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

搜索
首頁 > web前端 > js教程 > 正文

JavaScript文件系統(tǒng)訪問API

狼影
發(fā)布: 2025-10-16 11:21:02
原創(chuàng)
498人瀏覽過
File System Access API 允許現(xiàn)代瀏覽器直接操作本地文件,支持打開、讀取、寫入、保存及創(chuàng)建文件和遍歷目錄。1. 使用 showOpenFilePicker 選擇并讀取文本文件;2. 通過 showSaveFilePicker 創(chuàng)建新文件并保存內(nèi)容;3. 利用已有句柄編輯并寫回原文件;4. 調(diào)用 showDirectoryPicker 遍歷目錄中的文件。所有操作需用戶觸發(fā),確保安全,且可請求持久化權(quán)限。適用于代碼編輯器、筆記應(yīng)用等場景,提升 Web 應(yīng)用體驗。

javascript文件系統(tǒng)訪問api

JavaScript 文件系統(tǒng)訪問 API(File System Access API)讓網(wǎng)頁可以直接與用戶設(shè)備上的文件和目錄交互,提供更接近原生應(yīng)用的體驗。它允許用戶選擇文件、讀取、寫入、保存甚至創(chuàng)建新文件,而無需依賴傳統(tǒng)的 input[type=file] 或下載鏈接。

支持的功能

該 API 主要適用于現(xiàn)代 Chromium 瀏覽器(如 Chrome 86+、Edge 86+),目前在 Firefox 和 Safari 中暫不支持或處于實驗階段。

核心功能包括:

  • 打開本地文件并讀取內(nèi)容
  • 將更改保存回同一個文件
  • 創(chuàng)建新文件并保存到用戶指定位置
  • 訪問和遍歷目錄中的文件
  • 監(jiān)聽文件變化(未來可能支持)

基本使用方法

以下是常見操作的代碼示例。

立即學(xué)習(xí)Java免費(fèi)學(xué)習(xí)筆記(深入)”;

1. 打開一個文本文件

使用 window.showOpenFilePicker() 讓用戶選擇文件:

async function openFile() {
  try {
    const [fileHandle] = await window.showOpenFilePicker({
      types: [{
        description: 'Text files',
        accept: { 'text/plain': ['.txt'] }
      }]
    });
    const file = await fileHandle.getFile();
    const content = await file.text();
    return content;
  } catch (err) {
    console.error('用戶取消或發(fā)生錯誤', err);
  }
}
登錄后復(fù)制
2. 保存內(nèi)容到文件

使用 showSaveFilePicker() 獲取一個可寫文件句柄:

async function saveFile(content) {
  const fileHandle = await window.showSaveFilePicker({
    suggestedName: 'untitled.txt',
    types: [{
      description: 'Text files',
      accept: { 'text/plain': ['.txt'] }
    }]
  });

  const writable = await fileHandle.createWritable();
  await writable.write(content);
  await writable.close();
}
登錄后復(fù)制
3. 編輯已有文件并保存

如果已經(jīng)有一個文件句柄,可以直接寫回:

問問小宇宙
問問小宇宙

問問小宇宙是小宇宙團(tuán)隊出品的播客AI檢索工具

問問小宇宙77
查看詳情 問問小宇宙
async function editAndSave(fileHandle, newContent) {
  const writable = await fileHandle.createWritable();
  await writable.write(newContent);
  await writable.close();
}
登錄后復(fù)制
4. 讀取目錄內(nèi)容

使用 showDirectoryPicker() 選擇文件夾:

async function readDirectory() {
  const dirHandle = await window.showDirectoryPicker();

  for await (const entry of dirHandle.values()) {
    if (entry.kind === 'file') {
      const file = await entry.getFile();
      console.log(file.name);
    }
  }
}
登錄后復(fù)制

安全與權(quán)限

出于安全考慮,所有操作都需要用戶主動觸發(fā)(如點(diǎn)擊按鈕),不能自動執(zhí)行。瀏覽器會彈出系統(tǒng)級對話框,確保用戶知情并授權(quán)。

一旦獲得文件或目錄句柄,可在會話中重復(fù)使用,但持久化訪問需要請求權(quán)限:

const permission = await fileHandle.queryPermission({ mode: 'readwrite' });
if (permission !== 'granted') {
  await fileHandle.requestPermission({ mode: 'readwrite' });
}
登錄后復(fù)制

實際應(yīng)用場景

這個 API 特別適合以下類型的應(yīng)用:

  • 代碼編輯器(如在線 IDE)
  • 筆記應(yīng)用(直接保存為 .md 文件)
  • 圖像/音頻元數(shù)據(jù)編輯器
  • 配置文件管理工具

基本上就這些。只要瀏覽器支持,F(xiàn)ile System Access API 能極大提升 Web 應(yīng)用的操作能力和用戶體驗,讓網(wǎng)頁更像本地程序。不過要注意兼容性,并為不支持的環(huán)境準(zhǔn)備降級方案(比如傳統(tǒng) input + download)。

以上就是JavaScript文件系統(tǒng)訪問API的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!

最佳 Windows 性能的頂級免費(fèi)優(yōu)化軟件
最佳 Windows 性能的頂級免費(fèi)優(yōu)化軟件

每個人都需要一臺速度更快、更穩(wěn)定的 PC。隨著時間的推移,垃圾文件、舊注冊表數(shù)據(jù)和不必要的后臺進(jìn)程會占用資源并降低性能。幸運(yùn)的是,許多工具可以讓 Windows 保持平穩(wěn)運(yùn)行。

下載
來源:php中文網(wǎng)
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請聯(lián)系admin@php.cn
最新問題
開源免費(fèi)商場系統(tǒng)廣告
最新下載
更多>
網(wǎng)站特效
網(wǎng)站源碼
網(wǎng)站素材
前端模板
關(guān)于我們 免責(zé)申明 意見反饋 講師合作 廣告合作 最新更新
php中文網(wǎng):公益在線php培訓(xùn),幫助PHP學(xué)習(xí)者快速成長!
關(guān)注服務(wù)號 技術(shù)交流群
PHP中文網(wǎng)訂閱號
每天精選資源文章推送
PHP中文網(wǎng)APP
隨時隨地碎片化學(xué)習(xí)
PHP中文網(wǎng)抖音號
發(fā)現(xiàn)有趣的

Copyright 2014-2025 http://ipnx.cn/ All Rights Reserved | php.cn | 湘ICP備2023035733號