使用jQuery和下拉菜单的简单样式表切换器

Simple Stylesheet switcher using jQuery and a dropdown menu

本文关键字:样式 切换器 简单 jQuery 下拉菜单 使用      更新时间:2023-09-26

目前我有一个样式表切换器,它使用javascript根据下拉菜单中的选择加载新的样式表。

我想重新编写代码,使用jQuery而不是javascript。有人能帮我吗?我四处寻找jQuery解决方案,尽管有很多,但不使用下拉菜单。这是我的代码:

<head>
<link href="colour/light.css" rel="stylesheet" type="text/css">
<script type="text/javascript">
function changeScheme()
{ var _head = document.getElementsByTagName('head')[0];
  var _link = document.createElement('link');
_link.type = 'text/css';
_link.href = colour.colour.options[colour.colour.selectedIndex].value;
_link.rel = 'stylesheet';
_head.appendChild(_link);
}
</script>
</head>
<body>
<form action="#" name="colour" id="colour" onsubmit="return false;">
              <select name="colour" onchange="changeScheme();">
                <option value="colour/light.css">Light scheme</option>
                <option value="colour/dark.css">Dark scheme</option>
              </select>
            </form>
</body>

谢谢你的帮助!

<head>
<link href="colour/light.css" rel="stylesheet" type="text/css" id="stylelink">
<script type="text/javascript">
function changeScheme()
{ 
  $('#stylelink').attr('href',$('#colourselector').val());
}
</script>
</head>
<body>
    <form action="#" name="colour" id="colour" onsubmit="return false;">
          <select id="colourselector" name="colour" onchange="changeScheme();">
            <option value="colour/light.css">Light scheme</option>
            <option value="colour/dark.css">Dark scheme</option>
          </select>
    </form>
</body>

使您的解决方案100%jQuery(如Stefan建议的)

<head>
<link href="colour/light.css" rel="stylesheet" type="text/css" id="stylelink">
<script type="text/javascript">
$('#colourselector').change(function(){ 
  $('#stylelink').attr('href',$(this).val());
});
</script>
</head>
<body>
    <form action="#" name="colour" id="colour" onsubmit="return false;">
          <select id="colourselector" name="colour">
            <option value="colour/light.css">Light scheme</option>
            <option value="colour/dark.css">Dark scheme</option>
          </select>
    </form>
</body>