博客列表 >用cookie实现简单的用户自定义页面样式

用cookie实现简单的用户自定义页面样式

xiablog
xiablog原创
2021年11月24日 15:24:21756浏览

什么是 Cookie?

当 web 服务器向浏览器发送 web 页面时,在连接关闭后,服务端不会记录用户的信息。
  1. Cookie 的作用就是用于解决 “如何记录客户端的用户信息”:
  2. 当用户访问 web 页面时,他的名字可以记录在 cookie 中。
  3. 在用户下一次访问该页面时,可以在 cookie 中读取用户访问记录。

效果演示


代码演示如下:
首先创建一个one.html

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>用户自定义页面样式</title>
  6. <script src="cookie.js"></script>
  7. <style type="text/css">
  8. a{
  9. color: #000000;
  10. text-decoration: none;
  11. transition: all .5s;
  12. }
  13. a:hover{
  14. background-color: #f3f3f3;
  15. }
  16. </style>
  17. </head>
  18. <body>
  19. <input type="button" onclick="setBgColor('red')" value="设置页面背景色">
  20. <input type="button" onclick="setFontColor('yellow')" value="设置字体色">
  21. <p><a href="two.html">点击跳转到自定义样式的页面</a></p>
  22. <script>
  23. function setBgColor() {
  24. color = window.prompt("请输入页面背景颜色");
  25. setCookie('bgcolor', color, 3);
  26. }
  27. function setFontColor(color) {
  28. color = window.prompt("请输入字体颜色");
  29. setCookie('fontcolor', color, 3);
  30. }
  31. </script>
  32. </body>
  33. </html>

然后是two.html

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>自定义过后的页面样式</title>
  6. <style id="st"></style>
  7. <script src="cookie.js"></script>
  8. </head>
  9. <body>
  10. <h1>这是一个h1标签</h1>
  11. <h2>这是一个h2标签</h2>
  12. <p>这是一个段落标签</p>
  13. </body>
  14. <script>
  15. window.onload = function() {
  16. var bgcolor = getCookie('bgcolor');
  17. var fontcolor = getCookie('fontcolor');
  18. var stobj = document.getElementById('st');
  19. stobj.innerText = ' * {background-color:' + bgcolor + ';color:' + fontcolor + ';}';
  20. }
  21. </script>
  22. </html>

最后编写设置cookie的js代码,cookie.js

  1. //设置cookie
  2. function setCookie(cname,cvalue,exdays){
  3. var d = new Date();
  4. d.setTime(d.getTime()+(exdays*24*60*60*1000));
  5. var expires = "expires="+d.toGMTString();
  6. document.cookie = cname+"="+cvalue+"; "+expires;
  7. }
  8. //获取cookie
  9. function getCookie(cname){
  10. var name = cname + "=";
  11. console.log(name);
  12. var ca = document.cookie.split(';');
  13. for(var i=0; i<ca.length; i++) {
  14. var c = ca[i].trim();
  15. if (c.indexOf(name)==0) { return c.substring(name.length,c.length); }
  16. }
  17. return "";
  18. }
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议