两个类似的javascript函数,一个工作,另一个不工作,为什么?

时间:2013-03-18 14:21:21

标签: javascript html css

我是一个Javascript初学者,我试图让一些简单的代码工作。我添加了一个片段作为检查,以确保Javascript在页面中正常工作。它只是将一些文本从蓝色变为红色。

第二段代码应隐藏<div>,或根据所选值显示它。有人指出我正确的方向是行不通的吗?谢谢你的任何建议。

<!DOCTYPE html>
<html>
<head>
  <title>getElementById example</title>
  <script>
  function changeColor(newColor) {
    var elem = document.getElementById("para1");
    elem.style.color = newColor;
  }
  </script>

  <script>
       // EXPAND
    function Hide(elementid){
        document.getElementById(elementid).style.display = 'none';
    }

    function Show(elementid){
        document.getElementById(elementid).style.display = '';
    }
  </script>

</head>
    <body>
        <p id="para1">Some text here</p>
        <button onclick="changeColor('blue');">blue</button>
        <button onclick="changeColor('red');">red</button>

        <div id="one">ONE</div>
        <div id="two">TWO</div>

        <select>
            <Option value="javascript:Show('one');javascript:Hide('two')">one</option> 
            <Option value="javascript:Hide('one');javascript:Show('two')">two</option>
        </select>
    </body>
</html>

2 个答案:

答案 0 :(得分:6)

value属性不运行JavaScript。

您需要将change事件绑定到select元素,然后查看所选值以确定要显示或隐藏的值。

For example

<div id="one">ONE</div>
<div id="two">TWO</div>
<div id="three">THREE</div>

<select>
    <option>one
    <option>two
    <option>three
</select>

<script>
  function show(id) {
    document.getElementById(id).style.display = '';
  }
  function hide(id) {
    document.getElementById(id).style.display = 'none';
  }
  function whichDiv(event) {
    var select = event.target;
    var options = select.options;
    for (var i = 0; i < options.length; i++) {
      var option = options[i];
      if (option.selected) {
        show(option.value);
      } else {
        hide(option.value);
      }
    }
  }

  document.querySelector('select').addEventListener('change', whichDiv);
</script>

答案 1 :(得分:0)

我认为你应该使用blockdocument.getElementById(elementid).style.display = 'block';