【问题标题】:How to store a complete div in localstorage如何在本地存储中存储完整的 div
【发布时间】:2018-01-13 20:31:27
【问题描述】:

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

下面是我用来将整个 DIV 保存到本地存储的函数。我尝试了两种方法,一种没有将 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>

谢谢!

【问题讨论】:

    标签: javascript json


    【解决方案1】:

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

    相反,您可能想要保存outerHTML

    localStorage.setItem(key, annotatedtext.outerHTML);
    

    ...或者可能是innerHTML


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

    但即使是这样的检查也不足以处理您是否可以使用本地存储,因为隐私浏览在某些浏览器上的工作方式有些奇怪。要了解您是否可以使用本地存储:

    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) {
    }
    

    【讨论】:

    • 谢谢 - 是的,它成功了。我将进一步研究 stringify 方法。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-04-06
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-02-04
    • 1970-01-01
    相关资源
    最近更新 更多