用户名:
密 码:
当前位置: 主页 > 网页设计 > jquery >

jquery的应用之-动态调用css文件

点击:
银众网络-专业的域名注册虚拟主机服务商!虚拟主机全部为高带宽高配置、性能强劲。香港虚拟主机、美国虚拟主机等海外虚拟主机在速度和稳定性处于国际领先水平!每款虚拟主机均送同等容量的备份空间,随时备份让你的网站安全无忧,云主机更是功能强劲傲视群雄!

  jquery可以应用的范围很广,尤其是用标准构架的网站,只要通过简单的点击,就可以让网站在瞬间换个皮肤,当然可以通过其他方法实现,这里通过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不会应用到当前的文档,而只是备用

  复制代码 代码如下:

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


  这些就是点击后改变样式部分的代码,我们注意到有rel属性,有class属性,这些都是方便定位用的。

本文由虚拟主机域名注册服务商 银众网络(http://www.yinzhong.net) 整理,如需转载,请保留来源。
(责任编辑:admin)
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
栏目列表
推荐内容