localStorage关于ios10以下隐私模式不可用的问题

栏目: Html5 · 发布时间: 6年前

内容简介:最近老项目会员中心上报了一个问题,报错如下:部分用户在登录时会出现报错的情况,出现频率大概是每三天有一两个。 根据报错,很明显是setItem的问题。查看web docs没有说有兼容性问题

问题

最近老项目会员中心上报了一个问题,报错如下:

localStorage关于ios10以下隐私模式不可用的问题

部分用户在登录时会出现报错的情况,出现频率大概是每三天有一两个。 根据报错,很明显是setItem的问题。查看web docs没有说有兼容性问题

localStorage关于ios10以下隐私模式不可用的问题

继续了解,发现localstorage对ios11以下隐私模式有兼容问题,调用setItem会报错。即ios11以下的隐私模式不支持localstorage

解决办法

思路是在不兼容的浏览器(模式)下使用cookies来替代localstorage

const _isLocalStorageSupported = function() {    try {        window.localStorage.setItem('test', 1)        window.localStorage.removeItem('test')        return true    }catch(err) {        return false    }}

const getStorage = function(key) { ///localStorage.getItem / cookies    let res = ''    if(_isLocalStorageSupported()) {        res = window.localStorage.getItem(key)    }else { ///cookie        let name = `${key}=`        let ca = document.cookie.split(';')        for(let i=0; i<ca.length; i++) {            let c = ca[i].trim()            if (c.indexOf(name) === 0) {                 res = c.substring(name.length, c.length)            }        }    }    return res}const setStorage = function(key, val) { ///localStorage.setItem / cookies    if(_isLocalStorageSupported()) {        window.localStorage.setItem(key, val)    }else { ///cookie        let d = new Date();        d.setTime(d.getTime()+(30*24*60*60*1000));        let expires = `expires=${d.toGMTString()}`;        document.cookie = `${key}=${val}; ${expires}`;    }}复制代码

封装set和get的全局公共方法

补充

关于为啥 unhandled promise rejection 我有点不理解

localStorage关于ios10以下隐私模式不可用的问题

我是做了catch处理的,这个setItem是在.then()回调里执行的,应该被正常catch而不至于最后被进程捕获。很奇怪,有没有大佬知道原因的,欢迎评论告诉我,谢谢。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

CSS禅意花园

CSS禅意花园

[美] Dave Shea、Molly E. Holzschlag / 陈黎夫、山崺颋 / 人民邮电出版社 / 2007-6 / 49.00元

这本书的作者是世界著名的网站设计师,书中的范例来自网站设计领域最著名的网站——CSS Zen Garden(CSS禅意花园)。全书分为两个主要部分。第1章为第一部分,讨论网站“CSS禅意花同”及其最基本的主题,包含正确的标记结构和灵活性规划等。第二部分包括6章,占据了书中的大部分篇幅。 每章剖析“CSS禅意花园”收录的6件设计作品,这些作品围绕一个主要的设计概念展开,如文字的使用等。通过探索......一起来看看 《CSS禅意花园》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

MD5 加密
MD5 加密

MD5 加密工具

SHA 加密
SHA 加密

SHA 加密工具