手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >动态调用css文件——jquery的应用
动态调用css文件——jquery的应用
摘要:算是翻译吧,原文:http://15daysofjquery.com/style-sheet-switcheroo/12/可以应用的范围很广...

算是翻译吧,原文:http://15daysofjquery.com/style-sheet-switcheroo/12/

可以应用的范围很广,尤其是用标准构架的网站,比如说pjblog就可以,只要通过简单的点击,就可以让网站在瞬间换个皮肤,当然可以通过其他方法实现,这里通过jquery来实现,优点是代码简洁,可读性强

首先放上代码

复制代码 代码如下:

$(document).ready(function()

{

$('.styleswitch').click(function()

{

switchStylestyle(this.getAttribute("rel"));

returnfalse;

});

varc=readCookie('style');

if(c)switchStylestyle(c);

});

functionswitchStylestyle(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;

这句话的意思是使当前的对象失效

复制代码 代码如下:

functionswitchStylestyle(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属性的对象,每一个都执行相应的函数

下面来看看主页面的内容

复制代码 代码如下:

<linkrel="stylesheet"type="text/css"href="styles1.css"title="styles1"media="screen"/>

<linkrel="alternatestylesheet"type="text/css"href="styles2.css"title="styles2"media="screen"/>

<linkrel="alternatestylesheet"type="text/css"href="styles3.css"title="styles3"media="screen"/>

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

复制代码 代码如下:

<li><ahref="serversideSwitch.html?style=style1"rel="styles1"class="styleswitch">styles1</a></li>

<li><ahref="serversideSwitch.html?style=style2"rel="styles2"class="styleswitch">styles2</a></li>

<li><ahref="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

【动态调用css文件——jquery的应用】相关文章:

jquery 构造函数在表单提交过程中修改数据

javascript中this的四种用法

7个有用的jQuery代码片段分享

js兼容火狐显示上传图片预览效果的方法

动态加载jQuery的方法

Javascript实现div的toggle效果实例分析

用Node.js通过sitemap.xml批量抓取美女图片

关于IFRAME 自适应高度的研究

jQuery获取上传文件的名称的正则表达式

根据分辨率不同,调用不同的css文件

精品推荐
分类导航