javascript - 无法获取元素的值

标签 javascript tampermonkey

我正在尝试获取输入元素的值。该元素位于模态中,并且模态数据填充有不同的值,具体取决于我单击打开模态的按钮。

var modalBody = document.getElementsByClassName("modal-body");
for(var i = 0; i < modalbody.length; i++) {
    var mac = modalBody.item(i).getElementsByTagName('div')[2].getElementById("mac-name").value;
    alert(mac);
}

error: TypeError: modalBody.item(...).getElementsByTagName(...)[2].getElementById is not a function

我还尝试了 document.getElementById("mac-name").value; 但返回空白

<form method="post">
    <div class="modal-body">
        <div class="form-group">
            <label for="station-name" class="col-form-label">ID:</label>
            <input class="form-control" id="station-id" name="edit--id" required="" type="text" hidden="">
            <input class="form-control" id="station-name" name="edit--name" required="" type="text">
        </div>
        <div class="form-group">
            <label for="profile-name" class="col-form-label">Profile:</label>
            <select type="text" class="form-control" id="profile-name" name="edit-profile" required="">
            <option>name1</option>
            <option>name2</option>
            </select>
        </div>
        <div class="form-group">
            <label for="mac-name" class="col-form-label">MAC Address:</label>
            <input class="form-control" id="mac-name" name="edit-mac" required="" type="text">
        </div>
    </div>
</form>

最佳答案

而不是使用 getElementsByClassName 然后在每个元素上运行以下命令:

var mac = modalBody.item(i).getElementsByTagName('div')[2].getElementById("mac-name").value;

您可以使用 querySelectorAll 并传入 .modal-body div #mac-name。这将选择类 modal-body 元素内 div 内具有 id mac-name 的所有元素。您可以使用此结果循环遍历每个元素并获取每个值:

var macs = document.querySelectorAll('.modal-body div #mac-name');

参见下面的示例:

var macs = document.querySelectorAll('.modal-body div #mac-name');
for (var i = 0; i <  macs.length; i++) {
  var mac = macs[i].value;
  console.log(mac);
}
<form method="post">
  <div class="modal-body">
    <div class="form-group">
      <label for="station-name" class="col-form-label">ID:</label>
      <input class="form-control" id="station-id1" name="edit--id" required="" type="text" hidden="">
      <input class="form-control" id="station-name1" name="edit--name" required="" type="text">
    </div>
    <div class="form-group">
      <label for="profile-name" class="col-form-label">Profile:</label>
      <select type="text" class="form-control" id="profile-name1" name="edit-profile" required="">
        <option>name1</option>
        <option>name2</option>
      </select>
    </div>
    <div class="form-group">
      <label for="mac-name" class="col-form-label">MAC Address:</label>
      <input class="form-control" id="mac-name" name="edit-mac" value="Addr 1" required="" type="text">
    </div>
  </div>
  
  <div class="modal-body">
    <div class="form-group">
      <label for="station-name" class="col-form-label">ID:</label>
      <input class="form-control" id="station-id2" name="edit--id" required="" type="text" hidden="">
      <input class="form-control" id="station-name2" name="edit--name" required="" type="text">
    </div>
    <div class="form-group">
      <label for="profile-name" class="col-form-label">Profile:</label>
      <select type="text" class="form-control" id="profile-name2" name="edit-profile" required="">
        <option>name1</option>
        <option>name2</option>
      </select>
    </div>
    <div class="form-group">
      <label for="mac-name" class="col-form-label">MAC Address:</label>
      <input class="form-control" id="mac-name" name="edit-mac" value="Addr 2" required="" type="text">
    </div>
  </div>
</form>

关于javascript - 无法获取元素的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56714714/

相关文章:

javascript - 使用 React 添加和删除 CSS 类

javascript - 用户脚本在 Chrome 上的 Tampermonkey 中有效,但在 Firefox 上的 Greasemonkey 中无效

greasemonkey - 为什么我的Greasemonkey脚本没有更新?

javascript - 如何使 Javascript Tampermonkey 脚本搜索同一单词的小写和大写字符

javascript - 如何检查selenium WDS Jmeter中的div显示属性

javascript - 使用 Tweenjs 动画颜色

javascript - 如何在没有元素 ID 的下拉列表中使用 Javascript 选择选项?

javascript - 用户脚本每分钟单击一个 "Refresh"按钮,除非有输入?

javascript - neo4j 驱动程序 session 未执行

javascript - 使用 jquery mouseover 在 javascript 中递归过多