」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 在瀏覽器中進行文件操作

在瀏覽器中進行文件操作

發佈於2024-11-02
瀏覽:342

在浏览器中进行文件操作

在開發WebApp 時可能會遇到文件相關的操作,例如上傳文件到伺服器、下載文件到本地、快取文件等,下面會介紹幾種不同的方式進行文件操作。

基於標籤的上傳和下載

最常用的檔案上傳方式應該是使用 input 標籤,透過設定 input 標籤的 type=”file” 可以允許使用者從本機選擇檔案進行上傳。

function InputFile() {
    const [file, setFile] = useState(null);
    const handleChange = (e: React.ChangeEvent) => {
    const file = e.target.files?.[0];
    if (!file) return;
    setFile(file);
  };
    return 
}

檔案存取 API

檔案系統存取 API(File System Access API)屬於檔案系統 API 的一部分,可以透過使用 API 在使用者的操作下完成檔案的讀寫。

在使用此 API 進行檔案操作時會使用下列介面

  • showOpenFilePicker:用於顯示一個文件選擇器並允許使用者選擇一個或多個文件,然後傳回這些文件的句柄;
export function PickerFS() {
    const [file, setFile] = useState(null);
    const handleChooseFile = async () => {
    const fileHandles = await window.showOpenFilePicker();
    const file = await fileHandles[0].getFile();
    setFile(file);
  };
  return 
}
  • showSaveFilePicker:用於顯示一個檔案選擇器並允許使用者保存一個檔案(覆蓋或新建);
export function PickerFS() {
    const handleChooseFile = async () => {
    const directoryHandle = await window.showDirectoryPicker();
    const keys = directoryHandle.keys();
    // 打印该目录下所有文件的名字
    for await (const key of keys) {
      console.log(key);
    }
  };
  return 
}
  • showDirectoryPicker:用於顯示一個目錄選擇器並允許使用者選擇一個目錄;
export function PickerFS() {
    const [file, setFile] = useState(null);
    const handleDownloadFile= async () => {
    const opts = {
      suggestedName: "test.txt",
      types: [
        {
          description: "Text file",
          accept: { "text/plain": [".txt"] },
        },
      ],
    };

    const fileHandle = await window.showSaveFilePicker(opts);
    const writable = await fileHandle.createWritable();
    await writable.write("Hello, world!");
    await writable.close();
  };
  return 
}

來源私有檔案系統

來源私有檔案系統跟上面的檔案存取系統類似,都是檔案系統 API 的一部分,但是它們有個最直接的差異就是是否對使用者可見。 showXXX 介面都需要開啟檔案(目錄)選擇器,並且需要使用者主動選擇檔案(目錄),儲存的檔案也是需要儲存到使用者指定的路徑,但是來源私有檔案系統的互動不會對使用者可見,並且儲存的文件是經過處理的數據,使用者無法看到原始數據。

export function OpFs() {
  const handleChooseFile = async (event: React.ChangeEvent) => {
    const fileList = event.target.files;
    const file = fileList && fileList[0];
    if (!file) return;

    const opfsRoot = await navigator.storage.getDi rectory();
    const fileHandle = await opfsRoot.getFileHandle(file.name, { create: true });
    const writable = await fileHandle.createWritable();
    await writable.write(file);
    await writable.close();
  };

  return ;
}

await navigator.storage.getDirectory() 傳回一個表示使用者本機檔案系統根目錄的檔案句柄,然後透過getFileHandle 取得指定檔案的句柄,create 為true 表示如果沒有該檔案的話就會建立一個,接著使用createWritable建立可寫流,開發者可以透過這個可寫入流向指定檔案寫入數據,最後關閉可寫流。

注意事項

? 檔案存取系統和來源檔案系統在使用上很相似,對特定檔案或目錄的存取都需要透過檔案句柄(FileSystemFileHandle)或資料夾句柄(FileSystemDirectoryHandle)。

句柄可以理解為是對檔案本身的包裝,透過句柄的介面對檔案進行讀取(getFile)寫入(createWritable)操作。

參見

  • https://web.dev/articles/origin-private-file-system?hl=zh-cn#specifics_of_the_origin_private_file_system
  • https://developer.chrome.com/docs/capabilities/web-apis/file-system-access?hl=zh-cn
  • https://gine.me/posts/70f8e931bc17426fb54127948bcf4a0e
  • https://hughfenghen.github.io/posts/2024/03/14/web-storage-and-opfs/
版本聲明 本文轉載於:https://dev.to/yukiniro/zai-liu-lan-qi-zhong-jin-xing-wen-jian-cao-zuo-3nk1?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 為什麼 PhpMyAdmin 在 Ubuntu 12.04 上給出「MySQLi 擴充缺失」錯誤?
    為什麼 PhpMyAdmin 在 Ubuntu 12.04 上給出「MySQLi 擴充缺失」錯誤?
    PhpMyAdmin 錯誤:MySQLi 擴充缺失在 Ubuntu 12.04 遇到 PhpMyAdmin 問題?儘管安裝了 Apache2、PHP5、MySQL 和 PhpMyAdmin,您還是遇到了「mysqli 擴充遺失」錯誤。 儘管您已取消註解 php.ini 中的「extension=my...
    程式設計 發佈於2024-11-07
  • 如何使用 java.net.URLConnection 將檔案和附加參數上傳到 HTTP 伺服器?
    如何使用 java.net.URLConnection 將檔案和附加參數上傳到 HTTP 伺服器?
    在 Java 中使用附加參數將檔案上傳到 HTTP 伺服器將檔案上傳到 HTTP 伺服器是許多應用程式的常見需求。但是,有時也需要隨文件一起傳遞附加參數。這是一個允許您在不使用外部庫的情況下發送文件和參數的解決方案:java.net.URLConnection 和Multipart/Form-Dat...
    程式設計 發佈於2024-11-07
  • 如何在 PHP 中逐行讀取和處理文字檔?
    如何在 PHP 中逐行讀取和處理文字檔?
    在 PHP 中讀取文字檔案:逐步指南許多 Web 開發場景都涉及從文字檔案讀取資料。在 PHP 中,檔案處理函數提供了逐行讀取純文字檔案的便捷方法。讓我們分解一下使用 PHP 讀取文字檔案的過程。 讀取文字檔案的程式碼:以下PHP 程式碼片段示範如何讀取文字檔案並逐行處理其內容:<?php /...
    程式設計 發佈於2024-11-07
  • 我離不開的生產力工具(獎勵)
    我離不開的生產力工具(獎勵)
    大家好,你們的孩子 Nomadev 帶著另一篇貼文回來了!今天,我很高興與大家分享一些我每天使用的超酷的人工智慧工具。這些工具已成為我日常工作的重要部分,幫助我保持井井有條、有效率並完成更多工作。 在當今快節奏的世界中,我們都希望提高生產力和效率。借助人工智慧,有大量工具可以幫助我們管理任務、簡化...
    程式設計 發佈於2024-11-07
  • 在 Go/Templ 中製作一個乾淨、友好的 Spinner
    在 Go/Templ 中製作一個乾淨、友好的 Spinner
    无用的 HTML 你们可能认为在 HTML 中制作一个一致、干净且专业的旋转框是一项简单的任务...但是,令我们失望的是,没有标准的属性来告诉输入它应该只接受整数或小数值,所有的输入过滤都必须是JS。哎呀! 我将使用 Go、a-h/Templ、Tailwind 和我心爱的 Alpi...
    程式設計 發佈於2024-11-07
  • 您可以在沒有資料庫連線的情況下轉義字串以確保資料庫安全嗎?
    您可以在沒有資料庫連線的情況下轉義字串以確保資料庫安全嗎?
    在沒有資料庫連線的情況下轉義字串以確保資料庫安全測試與資料庫互動的程式碼時,透過正確轉義使用者輸入來防止SQL注入攻擊非常重要。然而,為每個測試連接到資料庫可能效率很低。有沒有辦法在沒有活動資料庫連線的情況下轉義字串? 沒有連接轉義的限制不幸的是,在沒有資料庫連線的情況下不可能可靠地轉義字串。 my...
    程式設計 發佈於2024-11-07
  • Entropix:最大化推理效能的取樣技術
    Entropix:最大化推理效能的取樣技術
    Entropix:最大化推理效能的取樣技術 根據 Entropix README,Entropix 使用基於熵的取樣方法。本文講解了基於熵和變熵的具體採樣技術。 熵和變熵 讓我們先解釋熵和變熵,因為它們是確定採樣策略的關鍵因素。 熵 在資訊理論中...
    程式設計 發佈於2024-11-07
  • 重疊方法支援多態性
    重疊方法支援多態性
    方法涵蓋: 這不僅僅是一個命名問題,而是 Java 的一個基本特性。 它是基於動態方法調度的概念。 動態方法調度: 是在運行時而非編譯時解決對重疊方法的呼叫的機制。 允許在 Java 中實現多態性。 運作原理: 超類別引用變數可以引用子類別物件。 當透過超類別引用呼叫重寫的方法時,要執行的...
    程式設計 發佈於2024-11-07
  • 如何對 Move_uploaded_file() 函數進行故障排除?
    如何對 Move_uploaded_file() 函數進行故障排除?
    Move_uploaded_file() 函數故障排除move_uploaded_file() 函數在檔案上傳機制中扮演至關重要的角色。然而,當遇到非功能性問題時,細緻的故障排除是必不可少的。 要解決這個問題,第一步是啟動 PHP 錯誤回報。這將顯示來自 move_uploaded_file() 函...
    程式設計 發佈於2024-11-07
  • 如何解決使用 UNION 時出現的「Select 語句中的不同欄位計數」錯誤?
    如何解決使用 UNION 時出現的「Select 語句中的不同欄位計數」錯誤?
    錯誤:Select 語句中的不同列計數執行使用UNION 運算子的查詢時,必須確保涉及的所有單獨SELECT 語句都遵守兩個基本標準:匹配列數:每個SELECT 語句必須在檢索的結果集中產生相同數量的列。 資料一致型別: 不同 SELECT 語句中對應列的資料型別應對齊。 問題分析考慮提供的查詢:S...
    程式設計 發佈於2024-11-07
  • 為什麼Python專案中的相對路徑會導致檔案未找到錯誤?
    為什麼Python專案中的相對路徑會導致檔案未找到錯誤?
    在 Python 專案中使用相對路徑存取檔案在 Python 專案中操作檔案時,為了方便起見,通常會使用相對路徑。然而,它們的行為可能變得不明確,特別是在處理多層次專案結構時。 考慮以下專案佈局:project /data test.csv /package ...
    程式設計 發佈於2024-11-07
  • Spring Boot初始化後如何執行程式碼?
    Spring Boot初始化後如何執行程式碼?
    Spring Boot初始化後執行程式碼在Spring Boot應用程式中,您可能會遇到需要在應用程式初始化後執行特定功能的情況。一旦應用程式功能齊全,這對於監視任務或執行其他操作通常是必要的。本文探討了利用 ApplicationReadyEvent 事件解決此挑戰的方法。 使用 Applicat...
    程式設計 發佈於2024-11-07
  • 如何使用 JavaScript 偵測 VPN
    如何使用 JavaScript 偵測 VPN
    在我們日益互聯的世界中,VPN(虛擬私人網路)既帶來了優勢,也帶來了挑戰。雖然它們幫助用戶維護隱私和安全,但它們也可能被用於惡意目的。 我們將深入探討如何使用 JavaScript 和 fetch API 在 Web 應用程式中實作 VPN 偵測。您可以使用任何您想要的API。 ...
    程式設計 發佈於2024-11-07
  • 如何使用Apache FOP在PDF文件中正確顯示漢字?
    如何使用Apache FOP在PDF文件中正確顯示漢字?
    Apache FOP 漢字顯示問題使用Apache FOP 列印PDF 文件時,漢字可能會顯示為“####”儘管安裝了必要的語言文件。此問題是由於預設配置中缺乏字體支援所引起的。 要解決此問題,需要三個步驟:步驟1:在FO 檔案中指定字體系列使用font-family 屬性指示所需的字體。例如:&l...
    程式設計 發佈於2024-11-07

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3