javascript - 为演示页面交换样式表 OnClick

标签 javascript css onclick

我的 JavaScript 经验水平很低。我在这个网站和网络上搜索了我的问题的答案,并找到了很多答案。我已经剪切并粘贴然后测试了解决方案,但没有一个对我有用。我不知道我哪里出错了。

我在这里选择了这段代码,但点击按钮没有任何改变。甚至不设置等待光标旋转,就好像它正在考虑它一样。 (测试样式表 angelfish 目前仅尝试更改 h2 颜色。)任何帮助将不胜感激,因为我确实需要在我的网站上执行此操作。

<!DOCTYPE html>
<html>
  <head>
    <link
      id="original"
      rel="stylesheet"
      type="text/css"
      href="https://cyndikirkpatrick.com/wp-content/themes/twentysixteen-child/ctc-style.css"
    />
  </head>
  <script>
    $('#original').click(function() {
      $('link[href="https://cyndikirkpatrick.com/wp-content/themes/twentysixteen-child/ctc-style.css"]').attr(
        'href',
        'style1.css'
      );
    });
    $('#angelfish').click(function() {
      $('link[href="https://cyndikirkpatrick.com/wp-content/themes/twentysixteen-child/angelfish.css"]').attr(
        'href',
        'style2.css'
      );
    });
  </script>
  <body>
    <h2>Javascript Change StyleSheet Without Page Reload</h2>
    <button id="original">Original</button><br />
    <button id="angelfish">Angelfish</button>
  </body>
</html>

https://cyndikirkpatrick.com/test/

我的最终目标:一个页面可以为我的库中的每个纹理集切换样式,以生成此页面的简化版本: https://cyndikirkpatrick.com/angelfish-texture-tiles-teal/

最佳答案

如果您修改 href,样式不会动态重置和重新加载。 但是,您可以删除样式并在正文中附加一个新样式。

// Remove
var elements = document.querySelectorAll('link[rel=stylesheet]');
for(var i=0;i<elements.length;i++){
    elements[i].parentNode.removeChild(elements[i]);
}

// Add
var head  = document.getElementsByTagName('head')[0];
var link  = document.createElement('link');
link.id   = cssId;
link.rel  = 'stylesheet';
link.type = 'text/css';
link.href = 'http://website.com/css/stylesheet.css';
link.media = 'all';
document.body.appendChild(link);

关于javascript - 为演示页面交换样式表 OnClick,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54929551/

相关文章:

javascript - 从 json 对象获取特定参数值

css - visual studio 2015 中的 Saas 无法正确解析 mixin 变量

javascript - 无法使用javascript选择html元素

html - 为什么 margin-top 与 inline-block 一起工作而不与 inline 一起工作?

javascript - 当我单击跨度时,如何获取跨度标签包含的文本并将其保存到隐藏的输入值?

html - 如何将多个 onClick 事件链接到 HTML 中的一个元素?我可以让他们更改 href 吗?

javascript - 如何让 jquery 移动控制组宽度 100%?

javascript - 请求失败,出现 "No ' Access-Control-Allow-Origin' header ”

javascript - 混合内容错误 (Http/Https)

javascript - 更改背景颜色 onclick HTML5