切换网页风格使用cookie存储(防止刷新丢失)

当在HTML本地文件中创建cookie时,可能会遇到不生效的问题。这通常由于浏览器的安全策略,如Chrome禁止file协议下的cookie。为解决此问题,可以将文件部署到服务器环境,或使用Firefox等其他浏览器。本文提供了两种可能的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/* Style Switcher by Paul Sowden, see A List Apart: http://www.alistapart.com/articles/alternate/ */

function setActiveStyleSheet(title) {
  var i, a, main;
  for(i=0; (a = document.getElementsByTagName("link")[i]); i++) {
    if(a.getAttribute("rel").indexOf("style") != -1 && a.getAttribute("title")) {
      a.disabled = true;
      if(a.getAttribute("title") == title) a.disabled = false;
    }
  };
  createCookie("test",title,30);
}

function getActiveStyleSheet() {
  var i, a;
  for(i=0; (a = document.getElementsByTagName("link")[i]); i++) {
    if(a.getAttribute("rel").indexOf("style") != -1 && a.getAttribute("title") && !a.disabled) return a.getAttribute("title");
  }
  return null;
}

function getPreferredStyleSheet() {
  var i, a;
  for(i=0; (a = document.getElementsByTagName("link")[i]); i++) {
    if(a.getAttribute("rel").indexOf("style") != -1
       && a.getAttribute("rel").indexOf("alt") == -1
       && a.getAt
在Web开发中,`Cookie`、`SessionStorage` 和 `LocalStorage` 都可以用于存储用户的认证信息或其他数据,但它们各自有不同的用途和特点。 ### Cookie Cookies 是一种小型文本文件,通常由服务器端设置并发送到客户端,在后续请求中会自动携带回服务器。适合存放少量的数据,并常用于保持用户登录状态等操作。 - **优点**:对于需要将一些标识符传递给服务端的情况非常有用;支持过期时间设定以及HTTPOnly属性提升安全性。 - **缺点**:大小限制较小(每个cookie不超过4KB),每次HTTP请求都会附带cookies增加网络负担。 #### 示例: ```javascript document.cookie = "username=John Doe; expires=Thu, 18 Dec 2023 12:00:00 UTC"; ``` ### SessionStorage Session Storage 提供了比 Cookies 更大的空间来保存非敏感性的数据,仅在同一浏览器标签页有效期内存在,关闭页面之后即消失。 - **优点**:容量较大(约5MB),不会随每一次 HTTP 请求一起发送至服务器端。 - **缺点**:不具备持久化能力,一旦刷新整个站点或切换窗口就会丢失所有数据。 #### 示例: ```javascript sessionStorage.setItem('key', 'value'); let value = sessionStorage.getItem('key'); ``` ### LocalStorage Local storage 类似 session storage ,但它没有生命周期的限制,除非手动清除否则一直保留着直到明确删除为止。 - **优点**:同样拥有较大的储存额度并且不影响性能传输过程因为无需附加于http头内。 - **缺点**:不适合存储敏感资料如令牌之类的由于容易受到XSS攻击影响。 #### 示例: ```javascript localStorage.setItem("token", token); var storedToken = localStorage.getItem("token"); if (storedToken) { // 用户已经登陆... } ``` 选择哪种方式取决于您的实际需求。如果您只需要短期维护某些状态,则可以选择 `sessionStorage`; 如果想要更长时间地记住用户偏好则考虑使用 `localStorage`. 而当涉及到身份验证相关的逻辑时最好还是通过 HTTPS 协议下的安全 cookies 来处理较为妥当.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值