博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

如何实现HTML页面无刷新更换CSS样式

Posted on 2009-04-01 12:47  linFen  阅读(2286)  评论(0编辑  收藏  举报
对于一个多页面的网站来说了,CSS的更换不能只简单的在一个页面中调用更换CSS功能更新这个页面头上链接的CSS地址,因为它不能保证在点击了别的页面后新的样式应该到新打开的页面中去,因此,一定要有一个全局性的变量来记录它,我选用的是SESSION,在用户点击了侧边模板下拉框中的模板时,触发了下拉框的ONCHANGE事件,执行了一段AJAX程序,程序的功能是将用户选中的模板信息发送给服务器,服务器接收新的模板信息后更新表示模板的SESSION值,然后向客户端返回成功信息,客户端则根据返回的成功信息来改变页面样式,注意:我在页面头中写的CSS链接信息是这样子的: 
程序代码:

div css xhtml xml Example Source Code Example Source Code [www.52css.com]
<LINK id=cssLink href="http://www.52css.com/css/css.aspx" type=text/css rel=stylesheet> 

  css.aspx是一个ASP.net的页面,它的作用只是单一的根据SESSION中的当前CSS模板信息来转向所应CSS样式表文件!这样子的处是客户端在接收到了服务器端成功更新SESSION的信息后刚不用考虑其它的东西,直接一句:

div css xhtml xml Example Source Code Example Source Code [www.52css.com]
       document.getElementById("cssLink").href=http://www.52css.com/css/document.getElementById("cssLink").href;

  将cssLink的href重新写一下儿,虽然是前后一模一样子的值,但这会激发CSS.ASPX页面重新读一下儿,这样子CSS.ASPX页面就能转到新更新的CSS样式表了!由于网站别的页面的样式表链接信息都是这样写的,所以每个页面加载时都是会应用最新更新的样式表的,这样子,网站无刷新的全局更新样式表就实现了!!