有没有可能在一个页面上有3-4个CSS,然后在任何事件上,比如说点击,改变整个网页的css。这样我们就可以给我们的用户改变主题的能力。我知道我们可以通过以下方式更改元素的css:
$("#myElementID").removeClass("class1").addClass("class2");发布于 2010-03-15 00:58:10
是的,这是可能的。通常,您要做的是编写一个JavaScript函数,该函数将在文档的<head>中更改、添加或删除样式表。为了使体验更好一些,您通常会将用户的偏好存储在cookie中。有一个article on A List Apart that show how to implement this。
当然,you can do this with jQuery..。你可能想看看jStyler的源代码。
发布于 2010-03-15 00:55:06
The CSS Zen Garden (参见第五个问题)最终决定最简单的方法就是刷新页面并设置一个新的CSS服务器端。
发布于 2010-03-15 00:58:31
CSS被嵌入到' link‘标签上的DOM中,所以你可以找到这个链接并添加/删除它
下面的代码展示了如何删除和添加新的DOM (我使用的是MS AJAX,请参阅方法$get,但您也可以用纯DOM或其他方言替换它):
var head = document.getElementsByTagName('head')[0];
var oldLink = $get("nameOfLink", head);
if(oldLink!=null)
head.removeChild(oldLink); //remove old entry
var s = document.createElement('link');
s.id="nameOfLink";
s.type = 'text/css';
s.rel="stylesheet";
s.charset ='utf-8';
s.href = "http://your-provided-url";
head.appendChild(s);https://stackoverflow.com/questions/2442894
复制相似问题