getElementsByClassName 不起作用

IT技术 javascript webforms html-table dynamic-data
2021-01-20 02:29:21

我编写了一个 php 页面,该页面将 mysql 数据库中的信息整齐地显示到表中。我想使用 onLoad 事件处理程序隐藏空表行。

这是一个示例表,其中包含<td>在没有内容时隐藏 a 的代码但我只能让它与不同的 ID 一起工作:

        <script type="text/javascript">
        function hideTd(id){
            if(document.getElementById(id).textContent == ''){
              document.getElementById(id).style.display = 'none';
            }
          }
        </script>
        </head>
        <body onload="hideTd('1');hideTd('2');hideTd('3');">
        <table border="1">
          <tr>
            <td id="1">not empty</td>
          </tr>
          <tr>
            <td id="2"></td>
          </tr>
          <tr>
            <td id="3"></td>
          </tr>
        </table>
    </body>

我想要做的是为<td>s使用一个类来实现同样的事情,同时只引用该类一次,而不是引用我想要删除的每个 id,这甚至不适用于我的动态内容。我尝试使用此代码:

    <script type="text/javascript">
    function hideTd(){
        if(document.getElementsByClassName().textContent == ''){
          document.getElementsByClassName().style.display = 'none';
        }
      }
    </script>
    </head>
    <body onload="hideTd('1');">
    <table border="1">
      <tr>
        <td class="1">not empty</td>
      </tr>
      <tr>
        <td class="1"></td>
      </tr>
      <tr>
        <td class="1"></td>
      </tr>
    </table>
</body>

但它不起作用。它应该隐藏<td>具有指定类的空s。我如何<td>使用类而不是 ID隐藏空的s?

2个回答

有几个问题:

  1. 类名(和 ID)不允许以数字开头
  2. 您必须将一个类传递给getElementsByClassName().
  3. 您必须迭代结果集。

示例(未经测试):

<script type="text/javascript">
function hideTd(className){
    var elements = document.getElementsByClassName(className);
    for(var i = 0, length = elements.length; i < length; i++) {
       if( elements[i].textContent == ''){
          elements[i].style.display = 'none';
       } 
    }

  }
</script>
</head>
<body onload="hideTd('td');">
<table border="1">
  <tr>
    <td class="td">not empty</td>
  </tr>
  <tr>
    <td class="td"></td>
  </tr>
  <tr>
    <td class="td"></td>
  </tr>
</table>
</body>

请注意,getElementsByClassName() 在 IE8 及包括 IE8 之前不可用

更新:

或者,您可以为该表指定一个 ID 并使用:

var elements = document.getElementById('tableID').getElementsByTagName('td');

获取所有td元素。

要隐藏父行,请使用parentNode元素属性:

elements[i].parentNode.style.display = "none";
更新:getElementsByClassName() 适用于 IE9。
2021-03-23 02:29:21
@新星:请看我更新的答案。
2021-04-03 02:29:21
它现在工作!但是如果 getElementsByClassName() 在 IE 中不可用,是否有另一种方法来隐藏一个空的 td 而不引用每个?另外,如果 td 为空,有没有办法隐藏整个 tr?谢谢
2021-04-10 02:29:21

如果你想通过 ClassName 来做,你可以这样做:

<script type="text/javascript">
function hideTd(className){
    var elements;

    if (document.getElementsByClassName)
    {
        elements = document.getElementsByClassName(className);
    }
    else
    {
        var elArray = [];
        var tmp = document.getElementsByTagName(elements);  
        var regex = new RegExp("(^|\\s)" + className+ "(\\s|$)");
        for ( var i = 0; i < tmp.length; i++ ) {

            if ( regex.test(tmp[i].className) ) {
                elArray.push(tmp[i]);
            }
        }

        elements = elArray;
    }

    for(var i = 0, i < elements.length; i++) {
       if( elements[i].textContent == ''){
          elements[i].style.display = 'none';
       } 
    }

  }
</script>