cookie和dom操作调用样式表实现网页换肤

2016-02-19 23:24 5 1 收藏

今天图老师小编给大家介绍下cookie和dom操作调用样式表实现网页换肤,平时喜欢cookie和dom操作调用样式表实现网页换肤的朋友赶紧收藏起来吧!记得点赞哦~

【 tulaoshi.com - Web开发 】

原理:通过存取cookie和dom操作调用不同的样式表文件来实现前台换肤.

 换肤示例下载:sour.rar

Html代码部分:

1.要有一个带id的样式表链接,我们要通过操作这个链接来调用不同的href.

link href="css/main0.css" rel="stylesheet" type="text/css" id="cssfile" /

2.皮肤选择按钮(后台为每个li添加onclick事件,触发换肤功能)

ul id="skin"               
li id="skin_0" title="灰色"灰色/li
li id="skin_1" title="绿色"绿色/li
li id="skin_2" title="黄色"黄色/li
li id="skin_3" title="蓝色"蓝色/li
li id="skin_4" title="粉色"粉色/li
li id="skin_5" title="紫色"紫色/li
/ul

Js部分:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

1.换肤方法

//设置cookie,按钮选中状态,页面皮肤
skin.setSkin=function(n){
    var skins =$("skin").getElementsByTagName("li");
    for (i=0;iskins.length;i++)
    {
        skins[i].className="";//初始化按钮状态
    }
    skin.setCookie(n);//保存当前样式
    $("skin_"+n).className="selected";//设置选中皮肤按钮的样式
    $("cssfile").href="css/main"+n+".css";//设置页面样式
}

2.存取cookie

//将当前皮肤n存到cookie
skin.setCookie=function(n){
    var expires=new Date();
    expires.setTime(expires.getTime()+24*60*60*365*1000);
    var flag="Skin_Cookie="+n;
    document.cookie=flag+";expires="+expires.toGMTString();
}
//返回用户设置的皮肤样式
skin.readCookie=function(){
    var skin=0;
    var mycookie=document.cookie;
    var name="Skin_Cookie";
    var start1=mycookie.indexOf(name+"=");
    if(start1==-1){
        skin=0;//如果没有设置则显示默认样式
    }
    else{
        var start=mycookie.indexOf("=",start1)+1;
        var end=mycookie.indexOf(";",start);
        if(end=-1){
            end=mycookie.length;
        }
        var values= unescape(mycookie.substring(start,end));
        if (values!=null)
        {
            skin=values;
        }
    }
    return skin;
   
}

3.绑定换肤按钮事件

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

skin.addEvent=function(){
    var skins =$("skin").getElementsByTagName("li");
    for (i=0;iskins.length;i++)
    {
        skins[i].onclick=function(){skin.setSkin(this.id.substring(5))};
    }
}

4.页面加载完成后设置皮肤样式

window.onload=function(){
    skin.setSkin(skin.readCookie());//根据读取cookie返回值设置皮肤样式
    skin.addEvent();//绑定按钮事件

来源:https://www.tulaoshi.com/n/20160219/1629861.html

延伸阅读
标签: Web开发
CSS用样式表美化你的网页 第1天:选择什么样的DOCTYPE 前言 大家好!这个系列文章是按阿捷自己制作这个站点的过程编写的。之前阿捷也一直没有制作过一个真正符合web标准的网站。现在边参考国外资料边制作,同时把过程中的心得和经验记录下来,希望对大家有点帮助。好了,让我们开始吧 第一天 开始制作符合标准的站点,第一件事情就是声明符...
标签: Web开发
最近因为帮一个网友很费神的修改了一个导航的CSS文件,还没有我自己重写code来的快,让我想起了写这篇文章。我发现很多web设计者对CSS写法的继承关系都有了一点了解,但是了解的还是不够深,不够透彻,所以今天打算把这个讲一下。 首先谈一下html文档,但凡接触过html语言的设计师,一定都会发现html的一个很明显的特点,那就是大多数代码...
     用web标准设计网站,过渡的方法主要是采用XHTML+CSS,css样式表是必不可少的。这就要求所有网页设计师必须熟练掌握CSS,如果你以前不常用,那么现在就开始学习吧。要制作符合web标准的网站,不懂CSS是设计不出漂亮的页面的。   事实上,所有表现的地方都需要用CSS来实现。我们以前都习惯用table来定位和布局,现在...
标签: Web开发
一.在学习css之前你应该掌握哪些基础知识 1.什么是网页,什么是超文本语言(html)。 2.会使用Dreamweaver等常用的网页编辑器。 Dreamweaver是现今最好的网站编辑工具之一,而Dreamweaver8增加的对CSS的支持更是你容易得来使用CSS,用它来给制作网页的CSS样式表会更简单、更方便。本教程教你如何利用Dreamweaver8在页面中加...
标签: Web开发
本文介绍如何在Dreamweaver 中使用层叠样式表 (CSS) 设置页面中的文本格式。您可以使用 CSS 以 HTML 无法提供的方式来设置文本格式和定位文本,从而能更加灵活自如地控制页面的外观。  了解 CSS  层叠样式表 (CSS) 是一系列格式设置规则,它们控制 Web 页面内容的外观。使用 CSS 设置页面格式时,内容与表现形式是相...

经验教程

871

收藏

66
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部