如何在静态HTM页面中实现无刷新的更换CSS样式
2007-12-14 09:18
281 查看
在静态HTM页面中实现无刷新的更换CSS样式!
系统原来的更换CSS模板是要重新刷新一下儿页面的,我一直都对这个功能很不满意,百分之九十五的功能都用AJAX无刷新的实现了,难道要在这个小小的更换页面CSS模板上给用户添点恶心吗?于是,昨天晚上好好考虑了这个功能上的实现,原来发现其实并不难,小改一下就OK了,现在系统上的模板更换是不用刷新页面来完成的,明显在感觉上比原来好得多了,下面谈谈经验吧:
对于一个多页面的网站来说了,CSS的更换不能只简单的在一个页面中调用更换CSS功能更新这个页面头上链接的CSS地址,因为它不能保证在点击了别的页面后新的样式应该到新打开的页面中去,因此,一定要有一个全局性的变量来记录它,我选用的是SESSION,在用户点击了侧边模板下拉框中的模板时,触发了下拉框的ONCHANGE事件,执行了一段AJAX程序,程序的功能是将用户选中的模板信息发送给服务器,服务器接收新的模板信息后更新表示模板的SESSION值,然后向客户端返回成功信息,客户端则根据返回的成功信息来改变页面样式,注意:我在页面头中写的CSS链接信息是这样子的:
程序代码
<LINK id=cssLink href="css.aspx" type=text/css rel=stylesheet>
css.aspx是一个ASP.net的页面,它的作用只是单一的根据SESSION中的当前CSS模板信息来转向所应CSS样式表文件!这样子的处是客户端在接收到了服务器端成功更新SESSION的信息后刚不用考虑其它的东西,直接一句:
document.getElementById("cssLink").href=document.getElementById("cssLink").href;
将cssLink的href重新写一下儿,虽然是前后一模一样子的值,但这会激发CSS.ASPX页面重新读一下儿,这样子CSS.ASPX页面就能转到新更新的CSS样式表了!由于网站别的页面的样式表链接信息都是这样写的,所以每个页面加载时都是会应用最新更新的样式表的,这样子,网站无刷新的全局更新样式表就实现了!!
系统原来的更换CSS模板是要重新刷新一下儿页面的,我一直都对这个功能很不满意,百分之九十五的功能都用AJAX无刷新的实现了,难道要在这个小小的更换页面CSS模板上给用户添点恶心吗?于是,昨天晚上好好考虑了这个功能上的实现,原来发现其实并不难,小改一下就OK了,现在系统上的模板更换是不用刷新页面来完成的,明显在感觉上比原来好得多了,下面谈谈经验吧:
对于一个多页面的网站来说了,CSS的更换不能只简单的在一个页面中调用更换CSS功能更新这个页面头上链接的CSS地址,因为它不能保证在点击了别的页面后新的样式应该到新打开的页面中去,因此,一定要有一个全局性的变量来记录它,我选用的是SESSION,在用户点击了侧边模板下拉框中的模板时,触发了下拉框的ONCHANGE事件,执行了一段AJAX程序,程序的功能是将用户选中的模板信息发送给服务器,服务器接收新的模板信息后更新表示模板的SESSION值,然后向客户端返回成功信息,客户端则根据返回的成功信息来改变页面样式,注意:我在页面头中写的CSS链接信息是这样子的:
程序代码
<LINK id=cssLink href="css.aspx" type=text/css rel=stylesheet>
css.aspx是一个ASP.net的页面,它的作用只是单一的根据SESSION中的当前CSS模板信息来转向所应CSS样式表文件!这样子的处是客户端在接收到了服务器端成功更新SESSION的信息后刚不用考虑其它的东西,直接一句:
document.getElementById("cssLink").href=document.getElementById("cssLink").href;
将cssLink的href重新写一下儿,虽然是前后一模一样子的值,但这会激发CSS.ASPX页面重新读一下儿,这样子CSS.ASPX页面就能转到新更新的CSS样式表了!由于网站别的页面的样式表链接信息都是这样写的,所以每个页面加载时都是会应用最新更新的样式表的,这样子,网站无刷新的全局更新样式表就实现了!!
相关文章推荐
- 如何实现HTML页面无刷新更换CSS样式
- Ajax实现静态刷新页面过程带加载旋转图片
- Ajax请求如何实现页面无刷新前进后退,将ajax请求保存至浏览器历史记录
- jsp+jquery 实现图片验证码(在主页面不刷新的情况下可更换图片)
- Android: 如何利用Handler处理和发送消息来实现页面刷新的功能
- Android: 如何利用Handler处理和发送消息来实现页面刷新的功能
- 如何用php+ajax实现页面的局部刷新?(转)
- 静态页面使用ajax刷新页面访问量通过easyui实现
- 如何实现AJAX获取数据的情况下改变地址却不刷新页面
- 两个独立静态htm页面间如何传值
- 如何通过JQ,Ajax来实现返回到上一个页面并进行刷新
- 如何实现刷新当前页面呢?借助js你将无所不能
- 如何直接将.aspx页面直接生成静态页面.htm (转载)
- Ajax 实现静态刷新页面 带加载旋转图片
- 如何用C#实现动态页面aspx的静态html转换
- php+ajax+json实现静态刷新页面
- 如何实现前端页面的数字自动刷新
- 使用jquery 如何编写实现请求本页面的无刷新操作
- servlet实现无刷新页面更换验证码
- 黄聪:PHP如何实现延迟一定时间后自动刷新当前页面、自动跳转header("refresh:1;url={$url}");