您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

动态调用css文件——jquery的应用_jquery

2025/5/20 20:18:44发布11次查看
算是翻译吧,原文:http://15daysofjquery.com/style-sheet-switcheroo/12/
可以应用的范围很广,尤其是用标准构架的网站,比如说pjblog就可以,只要通过简单的点击,就可以让网站在瞬间换个皮肤,当然可以通过其他方法实现,这里通过jquery来实现,优点是代码简洁,可读性强
首先放上代码
复制代码 代码如下:
$(document).ready(function()
{
        $('.styleswitch').click(function()
        {
                switchstylestyle(this.getattribute(rel));
                return false;
        });
        var c = readcookie('style');
        if (c) switchstylestyle(c);
});
function switchstylestyle(stylename)
{
        $('link[@rel*=style]').each(function(i)
        {
                this.disabled = true;
                if (this.getattribute('title') == stylename) this.disabled = false;
        });
        createcookie('style', stylename, 365);
}
这里说明一下:
复制代码 代码如下:
$('.styleswitch').click
这一句是对所有classname为styleswitch的对象定义点击事件,在jquery里用#表示id,比如$(#my_id)就可以定位到id为my_id的对象,定位classname为.,而定位tagname则不加任何修饰符,比如$(p),就是定位到所有p对象
readcookie和createcookie是两个自定义函数,这里没有给出来
复制代码 代码如下:
$('link[@rel*=style]').each(function(i)
这句话的意思是定位到link标签,其中有rel属性,并且rel属性里要包含style,对每一个这样的对象制定函数
复制代码 代码如下:
this.disabled = true;
这句话的意思是使当前的对象失效
复制代码 代码如下:
function switchstylestyle(stylename) 

    $('link[@rel*=style][@title]').each(function(i)  
    { 
        this.disabled = true; 
        if (this.getattribute('title') == stylename) this.disabled = false; 
    }); 
    createcookie('style', stylename, 365); 
}
这个函数的作用就是选择当前的样式
$('link[@rel*=style][@title]').each(function(i) 
有了前面的知识,这句话应该就不难理解了吧,就是所有标签名为link,包含rel属性,且rel属性里要包含style,同时还要有title属性的对象,每一个都执行相应的函数
下面来看看主页面的内容
复制代码 代码如下:
这里rel=alternate stylesheet,使得当前的css不会应用到当前的文档,而只是备用
复制代码 代码如下:
styles1 
styles2 
styles3
这些就是点击后改变样式部分的代码,我们注意到有rel属性,有class属性,这些都是方便定位用的 示例:http://www.healdream.com/upload/html/jquery/styleswitch/
下载:http://www.51files.com/?ytxg82nka8fa6tike4m0
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product