Hasilkan dan unduh file menggunakan Javascript ? Show Bayangkan Anda menggunakan Google Chrome dan Anda telah mengaktifkan opsi "Buka otomatis file yang diunduh", dan untuk nasib buruk Anda, Anda masuk ke situs web jahat dan itu menghasilkan unduhan file yang tidak dikenal. Anda tahu bagaimana cerita ini berakhir Namun, di browser terbaru ekstensi file yang tidak diketahui atau jarang diunduh diblokir dan prompt muncul jika Anda benar-benar ingin membuka file itu (setidaknya di Chrome) Oleh karena itu, pengunduhan file secara otomatis sulit dicapai dalam beberapa tahun terakhir, tetapi sekarang dengan diperkenalkannya HTML5, tugas ini menjadi lebih mudah untuk dicapai. Pada artikel ini kami akan menunjukkan kepada Anda beberapa trik untuk membuat dan mengunduh file secara langsung menggunakan Javascript murni Fungsi unduhan yang diterapkan sendiriFungsi sederhana berikut memungkinkan Anda menghasilkan unduhan file langsung di browser tanpa menghubungi server mana pun. Ia bekerja pada semua browser Siap HTML5 karena menggunakan atribut unduh dari elemen
Atribut unduhan menentukan bahwa target akan diunduh ketika pengguna mengklik hyperlink. Atribut ini hanya digunakan jika atribut href disetel Anda dapat melihat cuplikan ini beraksi di biola berikut Menggunakan perpustakaanBuat perpustakaan, bukan perang. FileSaver. js mengimplementasikan antarmuka Jika Anda perlu menyimpan file yang sangat besar lebih besar dari batasan ukuran blob atau tidak memiliki cukup RAM, lihat StreamSaver yang lebih canggih. js yang dapat menyimpan data langsung ke hard drive secara asinkron dengan kekuatan API aliran baru. Itu akan memiliki dukungan untuk kemajuan, pembatalan dan mengetahui kapan selesai menulis. Cuplikan berikut memungkinkan Anda membuat file (dengan ekstensi apa pun) dan mengunduhnya tanpa menghubungi server apa pun _Tabel berikut menunjukkan kompatibilitas FileSaver. js di browser yang berbeda BrowserBentuk sebagai namaFileUkuran GumpalanMaksDependensiFirefox 20+BlobYa800 MiBNoneFirefox < 20data. URINon/aBlob. jsChromeBlobYes500 MiBNoneChrome untuk AndroidBlobYes500 MiBNoneEdgeBlobYes?NoneIE 10+BlobYes600 MiBNoneOpera 15+BlobYes500 MiBNoneOpera < 15data. URINon/aBlob. jsSafari 6. 1+*BlobNo?NoneSafari < 6data. URINon/aBlob. js Catatan. meskipun mendukung browser terbaru, ada beberapa trik yang perlu Anda ketahui untuk memberikan dukungan penuh yaitu < 10Dimungkinkan untuk menyimpan file teks di IE <10 tanpa polyfill berbasis Flash. Lihat untuk detail lebih lanjut Safari 6. 1+Gumpalan terkadang dapat dibuka alih-alih disimpan—Anda mungkin harus mengarahkan pengguna Safari untuk menekan ?+S secara manual untuk menyimpan file setelah dibuka. Menggunakan jenis MIME iOSsaveA harus dijalankan dalam peristiwa interaksi pengguna seperti onTouchDown atau onClick; . Karena pembatasan di iOS, saveA terbuka di jendela baru alih-alih mengunduh, jika Anda ingin memperbaikinya, beri tahu Apple bagaimana bug ini memengaruhi Anda Fungsi Jika URL menggunakan protokol HTTP atau HTTPS, permintaan menyertakan semua cookie yang relevan, yaitu cookie yang disetel untuk nama host URL, flag aman, jalur, dan seterusnya. Cookie default, cookie dari sesi penelusuran normal, digunakan kecuali
Jika Ini adalah fungsi asinkron yang mengembalikan
0 _1 yang menentukan file apa yang ingin Anda unduh, dan preferensi lain yang ingin Anda atur terkait unduhan. Itu dapat berisi properti berikut 2 OpsionalTanda 3 yang memungkinkan pengunduhan untuk dilanjutkan meskipun mengalami kesalahan HTTP. Menggunakan flag ini, misalnya, memungkinkan pengunduhan halaman kesalahan server. Nilai default _4. Ketika diatur ke
7 OpsionalA 8 yang mewakili badan kiriman permintaan 9 OpsionalSebuah string yang mewakili tindakan yang ingin Anda ambil jika ada konflik nama file, seperti yang didefinisikan dalam tipe cookieStoreId OpsionalID penyimpanan cookie dari identitas kontekstual yang dikaitkan dengan pengunduhan. Jika dihilangkan, penyimpanan cookie default akan digunakan. Penggunaan membutuhkan "cookies" filename OpsionalA 8 mewakili jalur file relatif terhadap direktori unduhan default — ini menyediakan lokasi tempat Anda ingin menyimpan file, dan nama file apa yang ingin Anda gunakan. Jalur absolut, jalur kosong, komponen jalur yang dimulai dan/atau diakhiri dengan titik (. ), dan jalur yang berisi referensi balik (download() 4) akan menyebabkan kesalahan. Jika dihilangkan, nilai ini akan default ke nama file yang sudah diberikan ke file unduhan, dan lokasi tepat di dalam direktori unduhandownload() 5 OpsionalJika URL menggunakan protokol HTTP atau HTTPS, incognito OpsionalA _3. jika ada dan disetel ke true, kaitkan unduhan ini dengan sesi penjelajahan pribadi. Artinya, itu hanya akan muncul di pengelola unduhan untuk jendela pribadi apa pun yang saat ini terbukadownloads 6 Opsional 8 mewakili metode HTTP untuk digunakan jika downloads 8 menggunakan protokol HTTP[S]. Ini mungkin "GET" atau "POST"saveAs Opsional 3 yang menentukan apakah akan menyediakan dialog pemilih file untuk mengizinkan pengguna memilih nama file ( 6), atau tidak ( 4)Jika opsi ini dihilangkan, browser akan menampilkan pemilih file atau tidak berdasarkan preferensi pengguna umum untuk perilaku ini (di Firefox, preferensi ini diberi label "Selalu tanya Anda di mana menyimpan file" di sekitar. preferensi, atau Catatan. Firefox untuk Android memunculkan kesalahan jika 6. Parameter diabaikan ketika saveAs adalah 4 atau tidak disertakandownloads _8 8 mewakili URL untuk diunduhA Jika Anda menggunakan URL. createObjectURL() untuk mengunduh data yang dibuat dalam JavaScript dan Anda ingin mencabut URL objek (dengan revokeObjectURL) nanti (seperti yang sangat disarankan), Anda harus melakukannya setelah unduhan selesai. Untuk melakukannya, dengarkan unduhan. acara onChanged Tabel BCD hanya dimuat di browser dengan JavaScript diaktifkan. Aktifkan JavaScript untuk melihat data Cuplikan berikut mencoba mengunduh file contoh, juga menentukan nama file dan lokasi untuk menyimpannya, dan 9
Bagaimana cara mengubah nama file saat mengunduh JavaScript?Anda dapat mengaktifkan unduhan opsi jalur berbeda di browser Anda. Kemudian Anda dapat mengganti nama file menggunakan aktivitas typeinto untuk mengetik path dengan nama file baru selama eksekusi .
Bagaimana cara mendapatkan nama file yang diunduh dalam JavaScript?Penjelasan . var url = jendela. lokasi. nama jalan; var nama file = url. substring (url. lastIndexOf('/')+1); var url = jendela. lokasi. nama jalan; . substring (url. lastIndexOf('/')+1); Bagaimana cara mengubah nama unduhan suatu file?Ganti nama file . Di perangkat Android Anda, buka Files by Google Di bagian bawah, tap Telusuri Ketuk kategori atau perangkat penyimpanan. Anda akan melihat file dari kategori tersebut dalam daftar Di samping file yang ingin Anda ganti namanya, ketuk Panah bawah. Jika Anda tidak melihat Panah bawah , ketuk Tampilan daftar Ketuk Ganti Nama Masukkan nama baru Ketuk Oke Bagaimana cara mengunduh file dalam JavaScript?Jadi langkah-langkah untuk mendownload filenya adalah. . Gunakan ambil API untuk mengunduh file skrip Ubah data menjadi tipe blob Ubah objek blob menjadi string dengan menggunakan URL. buatObjectURL() Create an element to download the string.. |