Lakukan operasi fail dalam penyemak imbas

Patricia Arquette
Lepaskan: 2024-09-19 18:15:38
asal
941 orang telah melayarinya

Lakukan operasi fail dalam penyemak imbas

Apabila membangunkan WebApp, anda mungkin menghadapi operasi berkaitan fail, seperti memuat naik fail ke pelayan, memuat turun fail ke setempat, menyimpan fail cache, dll. Berikut akan memperkenalkan beberapa cara berbeza untuk memproses fail beroperasi.

Muat naik dan muat turun berasaskan teg

Cara yang paling biasa untuk memuat naik fail hendaklah menggunakan teg input Dengan menetapkan jenis="fail" teg input, anda boleh membenarkan pengguna memilih fail secara setempat untuk dimuat naik.

function InputFile() {
    const [file, setFile] = useState<file null>(null);
    const handleChange = (e: React.ChangeEvent<htmlinputelement>) => {
    const file = e.target.files?.[0];
    if (!file) return;
    setFile(file);
  };
    return <input onchange="{handleChange}" type="file">
}
</htmlinputelement></file>
Salin selepas log masuk

API akses fail

API Akses Sistem Fail (API Akses Sistem Fail) ialah sebahagian daripada API sistem fail Fail boleh dibaca dan ditulis di bawah operasi pengguna dengan menggunakan API.

Antara muka berikut akan digunakan apabila menggunakan API ini untuk operasi fail

  • showOpenFilePicker: digunakan untuk memaparkan pemilih fail dan membenarkan pengguna memilih satu atau lebih fail, dan kemudian mengembalikan pemegang kepada fail ini;
export function PickerFS() {
    const [file, setFile] = useState<file null>(null);
    const handleChooseFile = async () => {
    const fileHandles = await window.showOpenFilePicker();
    const file = await fileHandles[0].getFile();
    setFile(file);
  };
  return <button onclick="{handleChooseFile}">Click</button>
}
</file>
Salin selepas log masuk
  • showSaveFilePicker: digunakan untuk memaparkan pemilih fail dan membenarkan pengguna menyimpan fail (tulis ganti atau buat yang baharu);
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 <button onclick="{handleChooseFile}">Click</button>
}
Salin selepas log masuk
  • showDirectoryPicker: digunakan untuk memaparkan pemilih direktori dan membenarkan pengguna memilih direktori;
export function PickerFS() {
    const [file, setFile] = useState<file null>(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 <button onclick="{handleDownloadFile}">Click</button>
}
</file>
Salin selepas log masuk

Sistem Fail Peribadi Sumber

Sistem fail persendirian sumber adalah serupa dengan sistem capaian fail di atas, kedua-duanya adalah sebahagian daripada API sistem fail, tetapi perbezaan paling langsung antara mereka ialah sama ada ia boleh dilihat oleh pengguna. Antara muka showXXX semuanya perlu membuka pemilih (direktori) fail, dan pengguna perlu memilih fail (direktori) secara aktif Fail yang disimpan juga perlu disimpan ke laluan yang ditentukan oleh pengguna, tetapi interaksi sumber peribadi sistem fail tidak akan kelihatan kepada pengguna, dan fail yang disimpan Fail adalah data yang diproses dan data asal tidak dapat dilihat oleh pengguna.

export function OpFs() {
  const handleChooseFile = async (event: React.ChangeEvent<htmlinputelement>) => {
    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 <inputfile onchange="{handleChooseFile}"></inputfile>;
}
</htmlinputelement>
Salin selepas log masuk

await navigator.storage.getDirectory() mengembalikan pemegang fail yang mewakili direktori akar sistem fail setempat pengguna, dan kemudian mendapatkan pemegang fail yang ditentukan melalui getFileHandle create adalah benar, yang bermaksud jika fail itu tidak wujud, ia akan mencipta satu, dan kemudian menggunakan createWritable Cipta strim boleh tulis Pembangun boleh menggunakan strim boleh tulis ini untuk menulis data ke fail yang ditentukan, dan akhirnya menutup strim boleh tulis.

Perkara yang perlu diperhatikan

? Sistem akses fail sangat serupa dengan sistem fail sumber yang digunakan Akses kepada fail atau direktori tertentu memerlukan pemegang fail (FileSystemFileHandle) atau pemegang folder (FileSystemDirectoryHandle).

Hendal boleh difahami sebagai pakej untuk fail itu sendiri, dan fail dibaca (getFile) dan ditulis (createWritable) melalui antara muka pemegang.

Lihat

  • 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/

Atas ialah kandungan terperinci Lakukan operasi fail dalam penyemak imbas. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!