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

2016-02-19 10:39 8 1 收藏

图老师设计创意栏目是一个分享最好最实用的教程的社区,我们拥有最用心的各种教程,今天就给大家分享动态调用css文件——jquery的应用的教程,热爱PS的朋友们快点看过来吧!

【 tulaoshi.com - Web开发 】

算是翻译吧,原文: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属性的对象,每一个都执行相应的函数

下面来看看主页面的内容 

   代码如下:

 link rel="stylesheet" type="text/css" href="styles1.css" title="styles1" media="screen" / 
    link rel="alternate stylesheet" type="text/css" href="styles2.css" title="styles2" media="screen" / 
    link rel="alternate stylesheet" type="text/css" href="styles3.css" title="styles3" media="screen" /

这里rel="alternate stylesheet",使得当前的css不会应用到当前的文档,而只是备用 

代码如下:

lia href="serversideSwitch.html?style=style1" rel="styles1" class="styleswitch"styles1/a/li 
lia href="serversideSwitch.html?style=style2" rel="styles2" class="styleswitch"styles2/a/li 
lia href="serversideSwitch.html?style=style3" rel="styles3" class="styleswitch"styles3/a/li


这些就是点击后改变样式部分的代码,我们注意到有rel属性,有class属性,这些都是方便定位用的 示例:http://www.healdream.com/upLoad/html/jquery/styleswitch/

下载:http://www.51files.com/?YTXG82NKA8FA6TIKE4M0

来源:http://www.tulaoshi.com/n/20160219/1595391.html

延伸阅读
标签: Web开发
jQuery 是一个强大的Javascript类库,里面封装好了很多现有的方法和属性。可以使开发人员用很少的代码更好更快的开发出自己想实现的效果。 在平时的开发中,我们可能经常会用到jQuery。这里总结了一些经典的实例应用。分享给大家。 jQuery=轻松实现表单验证: 在我们的开发中,常会有注册或是添加信息的时候,难免的我们就会需要对表单进行验...
标签: Web开发
解决思路:修改样式表里z-index的值 解决办法: 代码如下: beforeShow: function (i,e) { var z = jQuery(i).closest(".ui-dialog").css("z-index") + 4; e.dpDiv.css('z-index', z); }
下截JNative组件 jnative.sourceforge.net/ 到这里下载JNative开源项目,我下载的是1.3.2 解压JNative-st1:chsdate isrocdate="False" islunardate="False" day="30" month="12" year="1899"1.3.2/st1:chsdate.zip 获得三个文件,分别是:JNativeCpp.dll,libJNativeCpp.so,JNative.jar 。 JNativeCpp.dll Windows下用的,拷贝到windows ...
常见的例子就是:一个站点上有多个页面样式提供浏览者选择。 同时,在选择了某样式后,再次打开该页面时,将仍然保持该样式。 自然会想到了Cookie技术 下面是HTML代码部分(另外再加需要的CSS文件就可以使用了): <HTML <HEAD <link ID="skin" rel="stylesheet" type="text/css" <TITLE换肤技术</TIT...
标签: Web开发
在webjx.com的文章中,并不提倡这样的方法,但是依然有很多CSSer会用到,这个资料保存在这里,以备大概查阅,请注意,不到不得已,请不要使用此方式。 !--[if lte IE 6] LINK rel="stylesheet" type="text/css" href="images/StyleSheet.css" / ![endif]-- !--[if ...

经验教程

348

收藏

14

精华推荐

CSS应用:根据文件类型显示不同图标

CSS应用:根据文件类型显示不同图标

久伴与我i好吗

动态CSS换肤技术

动态CSS换肤技术

然后呢一

jQuery AJAX 调用WebService实现代码

jQuery AJAX 调用WebService实现代码

专业苹果供应商

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