jQuery通过写入cookie实现更换网页背景的方法

  

jQuery 通过写入 cookie 实现更换网页背景的方法,实际上就是利用 cookie 存储用户选择的网页背景样式及其对应的 CSS 样式类名,在页面加载时根据 cookie 中存储的样式类名来设置页面背景样式。

具体实现步骤如下:

1. HTML 结构

在 HTML 文档的 head 标签中引入 jQuery 库和自定义 js 文件。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>更换网页背景</title>
  <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
  <script src="path/to/custom.js"></script>
</head>
<body>
  <!-- 页面内容 -->
</body>
</html>

2. CSS 样式

在 CSS 文件中定义多种背景样式,并分别用类名来命名。

.bg-white {
  background-color: #fff;
}

.bg-grey {
  background-color: #f2f2f2;
}

.bg-black {
  background-color: #000;
}

3. JavaScript 代码实现

首先需要判断 cookie 中是否有背景样式类名的存储记录,如果有,则根据存储的类名来设置页面对应的背景样式;如果没有,则默认使用一种背景样式。

$(document).ready(function () {
  var bgClass = getCookie("bgClass"); // 获取 cookie 中存储的背景样式类名
  if (bgClass) {
    $("body").addClass(bgClass); // 如果存在,则设置对应的背景样式
  } else {
    $("body").addClass("bg-white"); // 否则默认使用一种背景样式
  }

  // 给每个背景样式按钮添加点击事件处理程序
  $("#whiteBgBtn").on("click", function () {
    setCookie("bgClass", "bg-white"); // 在 cookie 中存储背景样式类名
    $("body").removeClass().addClass("bg-white"); // 设置页面对应的背景样式
  });
  $("#greyBgBtn").on("click", function () {
    setCookie("bgClass", "bg-grey");
    $("body").removeClass().addClass("bg-grey");
  });
  $("#blackBgBtn").on("click", function () {
    setCookie("bgClass", "bg-black");
    $("body").removeClass().addClass("bg-black");
  });
});

function setCookie(name, value, days) {
  var expires = "";
  if (days) {
    var date = new Date();
    date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
    expires = "; expires=" + date.toGMTString();
  }
  document.cookie = name + "=" + value + expires + "; path=/";
}

function getCookie(name) {
  var nameEQ = name + "=";
  var ca = document.cookie.split(';');
  for (var i = 0; i < ca.length; i++) {
    var c = ca[i];
    while (c.charAt(0) == ' ') {
      c = c.substring(1, c.length);
    }
    if (c.indexOf(nameEQ) == 0) {
      return c.substring(nameEQ.length, c.length);
    }
  }
  return null;
}

这段 JavaScript 代码实现了以下功能:

  1. 判断 cookie 中是否存在背景样式类名的存储记录,如果存在则设置页面的背景样式为该类名对应的样式,否则默认使用一种背景样式。
  2. 给每个背景样式按钮添加点击事件处理程序,当用户点击按钮时,将对应的背景样式类名存储到 cookie 中,并且设置页面的背景样式为该类名对应的样式。
  3. 定义了两个辅助函数 setCookie 和 getCookie,用于设置和获取 cookie 中的值。

示例一:使用 jQuery Cookie 插件

在上述代码中用纯 JavaScript 来实现 cookie 的读写操作可能会比较麻烦,这里我们可以借助 jQuery Cookie 插件来简化代码。

$(document).ready(function () {
  var bgClass = $.cookie("bgClass"); // 获取 cookie 中存储的背景样式类名
  if (bgClass) {
    $("body").addClass(bgClass); // 如果存在,则设置对应的背景样式
  } else {
    $("body").addClass("bg-white"); // 否则默认使用一种背景样式
  }

  // 给每个背景样式按钮添加点击事件处理程序
  $("#whiteBgBtn").on("click", function () {
    $.cookie("bgClass", "bg-white"); // 在 cookie 中存储背景样式类名
    $("body").removeClass().addClass("bg-white"); // 设置页面对应的背景样式
  });
  $("#greyBgBtn").on("click", function () {
    $.cookie("bgClass", "bg-grey");
    $("body").removeClass().addClass("bg-grey");
  });
  $("#blackBgBtn").on("click", function () {
    $.cookie("bgClass", "bg-black");
    $("body").removeClass().addClass("bg-black");
  });
});

示例二:添加 CSS3 动画效果

在页面加载时,我们可以给 body 元素添加一个动画效果,让页面背景逐渐出现,从而增加页面的交互体验。

body {
  opacity: 0;
  transition: opacity .5s ease-in-out;
}

body.show {
  opacity: 1;
}

修改 JavaScript 代码如下:

$(document).ready(function () {
  var bgClass = $.cookie("bgClass");
  if (bgClass) {
    $("body").addClass(bgClass);
  } else {
    $("body").addClass("bg-white");
  }
  setTimeout(function () {
    $("body").addClass("show");
  }, 100);

  // ...
});

这样,当页面加载时,body 元素将逐渐显示,从而给用户带来更好的使用体验。

相关文章