Rumah >hujung hadapan web >html tutorial >Mengapakah localstorage tidak berjaya menyimpan data?
Mengapakah menyimpan data ke storan setempat sentiasa gagal? Perlukan contoh kod khusus
Dalam pembangunan bahagian hadapan, kami selalunya perlu menyimpan data pada bahagian penyemak imbas untuk meningkatkan pengalaman pengguna dan memudahkan akses data seterusnya. Localstorage ialah teknologi yang disediakan oleh HTML5 untuk storan data sebelah pelanggan Ia menyediakan cara mudah untuk menyimpan data dan mengekalkan kegigihan data selepas halaman dimuat semula atau ditutup.
Namun, apabila kami menggunakan storan setempat untuk storan data, kadangkala kami menghadapi kegagalan storan. Jadi, mengapa menyimpan data ke storan setempat gagal? Di bawah ini kami akan meneroka beberapa kemungkinan sebab kegagalan storan storan setempat dan memberikan contoh kod khusus.
Berikut ialah contoh kod untuk menyemak saiz ruang storan:
function checkStorageSpace() { var storageSpace = 0; for (var i = 0; i < localStorage.length; i++) { var key = localStorage.key(i); var value = localStorage.getItem(key); storageSpace += key.length + value.length; } return storageSpace; } var data = "Lorem ipsum dolor sit amet, consectetur adipiscing elit."; if (checkStorageSpace() + data.length <= 5 * 1024 * 1024) { localStorage.setItem("data", data); }
Dalam kod di atas, kami mentakrifkan fungsi checkStorageSpace()
untuk mengulangi semua data dalam localstorage dan mengira saiznya. Kemudian, kami mentakrifkan data data
untuk disimpan dan memutuskan sama ada untuk menyimpan data dalam storan setempat dengan menilai sama ada ruang storan semasa adalah mencukupi. checkStorageSpace()
来遍历localstorage中的所有数据并计算其大小。然后,我们定义了一个要存储的数据data
,通过判断当前存储空间是否足够来决定是否将数据存储到localstorage中。
下面是一个将数据转换为字符串类型的示例代码:
var data = { name: "John", age: 25, email: "john@example.com" }; localStorage.setItem("data", JSON.stringify(data));
在上述代码中,我们定义了一个对象data
,然后使用JSON.stringify()
方法将其转换为字符串类型,并将其存储到localstorage中。
setItem()
方法来存储数据时,它会直接触发存储事件。如果浏览器当前的存储空间已满或者用户禁用了localstorage,就会导致存储失败。为了解决这个问题,我们可以在存储之前检查localstorage是否可用,并在必要时给出提示。
下面是一个检查localstorage是否可用的示例代码:
function checkLocalStorageAvailability() { try { var testKey = "__test__"; localStorage.setItem(testKey, testKey); localStorage.removeItem(testKey); return true; } catch (e) { return false; } } if (checkLocalStorageAvailability()) { localStorage.setItem("data", "Lorem ipsum dolor sit amet, consectetur adipiscing elit."); } else { alert("Localstorage is not available!"); }
在上述代码中,我们定义了一个函数checkLocalStorageAvailability()
Berikut ialah contoh kod untuk menukar data kepada jenis rentetan:
rrreee🎜Dalam kod di atas, kami mentakrifkan objekJSON.stringify() kaedah menukarnya kepada jenis rentetan dan menyimpannya ke dalam storan setempat. 🎜<ol start="3">🎜 Kegagalan mencetuskan peristiwa storan: Operasi storan storan setempat adalah segerak, yang bermaksud apabila kita memanggil kaedah <code>setItem()
untuk menyimpan data, ia akan mencetuskan secara langsung acara penyimpanan. Jika ruang storan semasa penyemak imbas penuh atau pengguna telah melumpuhkan storan setempat, kegagalan storan akan berlaku. 🎜🎜🎜Untuk menyelesaikan masalah ini, kami boleh menyemak sama ada storan setempat tersedia sebelum menyimpan dan memberi gesaan jika perlu. 🎜🎜Berikut ialah contoh kod untuk menyemak sama ada localstorage tersedia: 🎜rrreee🎜Dalam kod di atas, kami mentakrifkan fungsi checkLocalStorageAvailability()
untuk cuba menyimpan kunci ujian ke dalam localstorage dan memadamkannya serta-merta . Jika operasi ini berjaya, storan setempat tersedia. 🎜🎜Melalui kod sampel di atas, kami boleh menyelesaikan beberapa masalah biasa kegagalan storan storan setempat. Dalam pembangunan sebenar, kami juga boleh menggunakan pernyataan cuba-tangkap untuk mengendalikan pengecualian dalam operasi storan untuk meningkatkan keteguhan program. 🎜🎜Untuk meringkaskan, apabila menyimpan data ke storan setempat gagal, kami perlu mempertimbangkan isu seperti had ruang storan, ralat penukaran jenis data dan kegagalan pencetus peristiwa storan. Dengan mengendalikan isu ini dengan betul, kami boleh menggunakan storan setempat dengan berkesan untuk mencapai penyimpanan data yang berterusan. 🎜Atas ialah kandungan terperinci Mengapakah localstorage tidak berjaya menyimpan data?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!