时间:2021-05-25
算是翻译吧,原文: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:///?YTXG82NKA8FA6TIKE4M0
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
如果你有很多关联的CSS文件要一起加载,或者想动态的加载不同的CSS文件,那么下面的方法你一定对你有帮助。Jquery动态加载Js和Css扩展方法$.exten
使用jquery动态加载js,css文件复制代码代码如下:$.extend({includePath:'',include:function(file){var
EasyLoader是可以动态加载脚本和CSS文件,也可以动态加载EasyUI已有组件需要引用EasyLoader.js文件,注意:这里就不需要引用jquery
由于jquery支持css3,所有能很好的兼容很多浏览器,所以通过jquery来使用css样式比较好 为定义好的css样式可以调用元素的css方法添加样式
本文实例讲述了jquery实现动态改变css样式的方法。分享给大家供大家参考,具体如下:jquery几乎成了现在开发WEB应用的标准JS库,这与其简单性和易用性