使用javascript控制cookie显示和隐藏背景图

时间:2024-04-23 09:33:26 

每当重大节日期间,各大主流网站首页会披上节日的盛装,设计者一般会使用大幅背景图片来获得更好的视觉冲击效果,当然,也要考虑到有些用户不习惯这大背景图,那么在背景图上放置“关闭”按钮是有必要的,用户只要点击“关闭背景”按钮,大幅背景图将会消失。

我们使用javascript来控制背景图片的显示和隐藏,当点击关闭按钮时,控制CSS使页面不加载背景图,同时记录COOKIE相关参数,并设置cookie的有效期,那么在cookie有效期内刷新页面,是不会再加载背景图的,如果cookie失效,则又会重新加载背景图片。

HTML

一般背景图片的关闭按钮都是放在页面头部的,我们在页面的顶部放置关闭背景的按钮,当然这个按钮是做好的图片。


<div id="top">
    <em id="close_btn" title="关闭背景"></em>
</div>

CSS

还需要准备大背景图片,我们从网上找张大背景图拿来用,用CSS做简单的页面布局。

 


*{margin:0; padding:0}
body{font:12px/18px "Microsoft Yahei",Tahoma,Arial,Verdana,"\5b8b\4f53", sans-serif;}
#top{clear:both;width:1000px;height:60px;margin:0 auto;overflow:hidden;position:relative;}
#close_btn{width:60px;height:20px;position:absolute;right:0;bottom:25px;cursor:pointer;
display:block;z-index:2;}

部署完了css后,页面还没有什么效果,我们需要使用javascript来加载背景图片。
Javascript
当第一次加载页面时(这时还没有设置cookie等),当然要把背景图片加载,显示完整的页面效果。当我们点击“关闭”按钮时,这个时候Javascript会把页面已经加载的背景图片干掉,即不显示出来,并且设置cookie,通过cookie的过期时间来控制大背景图片是否显示。即当下次刷新页面时,如果cookie未过期,则不会加载大背景图片,反之则加载大背景图片,请看代码:

 


$(function(){
    if(getCookie("mainbg")==0){
        $("body,html").css("background","none");
        $("#close_btn").hide();
    }else{
        $("body").css("background","url(images/body_bg.jpg)) no-repeat 50% 0");
        $("html").css("background","url(images/html_bg.jpg) repeat-x 0 0");
        $("#close_btn").show().css("background","url(images/close_btn.jpg) no-repeat");
    }
    //点击关闭
    $("#close_btn").click(function(){
        $("body,html").css("background","none");
        $("#close_btn").hide();
        setCookie("mainbg","0");
    });
})

很显然,我们是通过设置页面元素的CSS背景background属性来控制背景图的加载,并且通过getCookie()和setCookie()两个自定义函数来读取和设置cookie的。

 


//设置cookie
function setCookie(name,value){
    var exp = new Date(); 
    exp.setTime(exp.getTime() + 1*60*60*1000);//有效期1小时
    document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
}
//取cookies函数
function getCookie(name){
    var arr = document.cookie.match(new RegExp("(^| )"+name+"=([^;]*)(;|$)"));
    if(arr != null) return unescape(arr[2]); return null;
}

标签:javascript,cookie,隐藏背景
0
投稿

猜你喜欢

  • python 代码实现k-means聚类分析的思路(不使用现成聚类库)

    2021-05-28 06:30:24
  • 仅用几行Python代码就能复制她的U盘文件?

    2021-11-20 15:12:19
  • phpcms手机内容页面添加上一篇和下一篇

    2024-05-11 09:54:05
  • 关于Python包导入报错的问题总结

    2021-02-05 18:13:46
  • asp中设置session过期时间方法总结

    2013-06-01 19:52:04
  • 一起来学习Python的元组和列表

    2023-07-23 02:43:32
  • Mysql 5.7.19 免安装版遇到的坑(收藏)

    2024-01-19 12:18:39
  • SQL Server密码管理的六个危险判断

    2008-10-23 13:57:00
  • Python最基本的数据类型以及对元组的介绍

    2022-03-26 07:04:07
  • Django中F函数的使用示例代码详解

    2023-11-21 00:56:06
  • JS作用域链详解

    2024-04-17 10:04:56
  • ASP XML操作类代码

    2011-03-08 10:47:00
  • Python Matplotlib绘图基础详细教程

    2024-01-16 04:34:41
  • 用Python读取几十万行文本数据

    2023-10-13 21:56:04
  • Python中的默认参数实例分析

    2023-02-20 20:19:38
  • Python制作简单的网页爬虫

    2022-10-09 12:49:16
  • 基于layPage插件实现两种分页方式浅析

    2024-05-28 15:40:53
  • python如何对实例属性进行类型检查

    2021-08-17 09:28:19
  • python套接字流重定向实例汇总

    2022-04-15 07:53:41
  • Orcale权限、角色查看创建方法

    2024-01-20 04:22:02
  • asp之家 网络编程 m.aspxhome.com