后台用另一种方法append LI 以及safari无法显示localstorage?

发布于 2022-08-28 00:37:39 字数 842 浏览 17 评论 0

昨天有同学说代码不好看,不标准,看不懂等等问题,另外也确实碰到localstorage在safari中无法显示的问题。
那么今天尝试在后台用另一种方法append LI.但是没有pass,是哪里出问题了?

前台

 <ul id="list"></ul>

后台开始用innerhtml,后来改用creatTextNode

var fresh= JSON.parse(storage.getItem("data"));
var list = document.getElementById("list");  
    for(var i=0;i<fresh.length;i++){ 
     var li = document.createElement("li");  
     var node = document.createTextNode(fresh[i]);
         li.appendChild(node);
         list.appendChild(li);     
     }

无果。?innerHTML 和creatTextNode的区别有人愿意讲下之间的使用经验么?


探索了一下,貌似找到以上不Pass的原因了,因为把ul之间的script引用改成了onload时候调用,添加onload后chrome顺利运行,但是!!!safari依旧不显示,即使不调取storage数据也不显示!!所以这根本是safari对Js的支持问题么?

另外Safari对CAMERA定义层的显示是坨黑块。~

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

她比我温柔 2022-09-04 00:37:39

后来去苹果店测试了,最新版本的所有ios和apple硬件设备都可以通过。 系统我和店家是一摸一样的最新版本,估计可能是我的上一代miniPad硬件支持问题。 标准的无解Bug。。

不回头走下去 2022-09-04 00:37:39

看LZ是用iPad的Safari来调试的,指出一点问题。
1.摄像头一坨黑的问题

另外Safari对CAMERA定义层的显示是坨黑块。~

这是因为iOS不支持获取摄像头元素,所以会是一团黑。

2.在Stack那里找到了类似的答案[1]。别人是建立了一个函数,然后把这个API包装了进去,同时检查API是否可用,可用就返回API。代码贴在这里,供你参考。

function getStorage() {
var storageImpl;

 try { 
        localStorage.setItem("storage", ""); 
        localStorage.removeItem("storage");
        storageImpl = localStorage;
 }
 catch(err) { 
     storageImpl = new LocalStorageAlternative();
 }

return storageImpl;

}

function LocalStorageAlternative() {

var structureLocalStorage = {};

this.setItem = function (key, value) {
    structureLocalStorage[key] = value;
}

this.getItem = function (key) {
    if(typeof structureLocalStorage[key] != 'undefined' ) {
        return structureLocalStorage[key];
    }
    else {
        return null;
    }
}

this.removeItem = function (key) {
    structureLocalStorage[key] = undefined;
}
}


cusSto=getStorage();
拧巴小姐 2022-09-04 00:37:39
var fresh= JSON.parse(storage.getItem("data"));

如果我没猜错的话楼主想用的是HTML5 LocalStorage,但楼主把API搞错了,应该这样的

var fresh= JSON.parse(localStorage.getItem("data"));

innerHTML和createTextNode差别比较大,前者等于是赋值,后者是创建一个DOM。而通过DOM则可以更多的事情,比如用node.parentElement来获取父元素。

楼主在做开发的时候,最好用浏览器自带的开发工具,比如说在chrome右键菜单里,有个‘审查元素’,在这里可以查看文档结构,调试js,性能分析等等。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文