如何在localstorage中存储一个完整的div

时间:2018-01-13 12:28:26

标签: javascript json

我正在尝试创建一个基本的文本注释器。 我想保存带有注释的文本(一个完整的div),其中包含本地存储中的所有标签。 到目前为止,我的方法很幼稚,我想理解为什么它不起作用。非常感谢您的帮助!

以下是我用来将整个DIV保存到localstorage的功能。我尝试了两种方法,一种不将div转换为JSON,另一种没有。

function saveText() {
if (localStorage) {
    var key = "latest text annotated" ;
    var annotatedtext = document.getElementById("text");
    var annotatextTextStringified = JSON.stringify(annotatedtext);
    localStorage.setItem(key, annotatextTextStringified);
  }
else {
    console.log("Error: you don't have localStorage!");
  }
}

当我保存到本地存储带注释的文本时,保存的值只是HTML元素。 当我将带注释文本的字符串化版本保存到本地存储时,它会保存一个空的JSON。

我想了解:

  • 为什么我无法将整个div字符串化。
  • 为什么我无法拯救整个div。

如果两者都不可能,那么保存新注释文本并检索它的最佳方法是什么?

例如,我试图保存的DIV就是这个:

<div id="text">
  <p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam congue tortor eget pulvinar lobortis.
Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Nam ac dolor augue.
Pellentesque mi mi, laoreet et dolor sit amet, ultrices varius risus. Nam vitae iaculis elit.
Aliquam mollis interdum libero. Sed sodales placerat egestas. Vestibulum ut arcu aliquam purus viverra <span class="highlight" id="1">dictum</span> vel sit amet mi.
 </p>

谢谢!

1 个答案:

答案 0 :(得分:3)

它不起作用,因为JSON.stringify不是序列化div的正确方法。 JSON.stringify仅包含对象的“自有”属性,但您在div(主要是innerHTMLouterHTML)上关注的属性是继承的,而不是“拥有”。< / p>

相反,您可能希望保存outerHTML

localStorage.setItem(key, annotatedtext.outerHTML);

......或可能innerHTML

附注:您检查浏览器是否有localStorage是不正确的。如果if (localStorage)完全未声明(因为它将在没有本地存储的浏览器中),localStorage将抛出错误。您可能想要if (typeof localStorage !== "undefined"),它不会抛出,但如果localStorage完全未声明,则为真。

但即便检查也不够彻底,无法处理是否可以使用本地存储,因为私密浏览在某些浏览器上的工作方式有些奇怪。要知道您是否可以使用本地存储:

var canUseStorage = false;
try {
    var key = "test" + Date.now() + Math.random();
    localStorage.setItem(key, key);
    if (localStorage.getItem(key) == key) {
        canUseStorage = true;
        localStorage.removeItem(key);
    }
}
catch (e) {
}