使用 event.currentTarget 获取子项的索引

get index of child with event.currentTarget

本文关键字:索引 获取 event currentTarget 使用      更新时间:2023-09-26

如何摆脱jQuery的".index()"?我正在寻找的只是一种获取按钮索引的本机方法,请参阅下面的源代码(工作完美,但我真的找不到任何 Vanilla-JS 解决方案,我不想使用 jQuery 完成这么小的任务)。谢谢。

    function navButtonClick(ev) {
        var buttonIndex = $(ev.currentTarget).index(); /* How to get rid of jQuery? */
        document.getElementById("output").innerHTML = buttonIndex;
    }
    function startTemplate() {
        var i;
        var navItems = document.querySelectorAll("#navigation button");
        for (i=0; i < navItems.length; i++) {
            navItems[i].addEventListener("click", navButtonClick);
        }
    }
    document.addEventListener("DOMContentLoaded", startTemplate);
    
The HTML part looks like this:
    <nav id="navigation" role="navigation">
        <button type="button"> <em>Navi tab 1</em> </button>
        <button type="button"> Navi tab 2 </button>
        <button type="button"> Navi tab 3 </button>
        <button type="button"> Navi tab 4 </button>
    </nav>
    <div id="output"></div>

你可以

这样做:

function navButtonClick(ev) {
    var buttonIndex = Array.prototype.indexOf.call(this.parentElement.children, this);
    document.getElementById("output").innerHTML = buttonIndex;
}
function startTemplate() {
    var i;
    var navItems = document.querySelectorAll("#navigation button");
    for (i=0; i < navItems.length; i++) {
        navItems[i].addEventListener("click", navButtonClick);
    }
}
document.addEventListener("DOMContentLoaded", startTemplate);

检查下面的代码段:

function navButtonClick(ev) {
  var buttonIndex = Array.prototype.indexOf.call(this.parentElement.children, this);
  document.getElementById("output").innerHTML = buttonIndex;
}
function startTemplate() {
  var i;
  var navItems = document.querySelectorAll("#navigation button");
  for (i = 0; i < navItems.length; i++) {
    navItems[i].addEventListener("click", navButtonClick);
  }
}
document.addEventListener("DOMContentLoaded", startTemplate);
<nav id="navigation" role="navigation">
  <button type="button"> <em>Navi tab 1</em> 
  </button>
  <button type="button">Navi tab 2</button>
  <button type="button">Navi tab 3</button>
  <button type="button">Navi tab 4</button>
</nav>
<div id="output"></div>

您可以通过两种不同的方式执行此操作。首先,在添加事件侦听器时将按钮的索引传递给相应的函数:

function navButtonClick(buttonIndex) {
    document.getElementById("output").innerHTML = buttonIndex;
}
function startTemplate() {
    var i;
    var navItems = document.querySelectorAll("#navigation button");
    for (i = 0; i < navItems.length; i++) {
        navItems[i].addEventListener("click", navButtonClick.bind(null, i));
    }
}
startTemplate();

JSFiddle

其次,创建一个函数来动态检查元素的索引:

function navButtonClick() {
    document.getElementById("output").innerHTML = getIndex(this);
}
function getIndex(elm) {
  var parent = elm.parentElement;
  for (var i = 0; i < parent.children.length; i++) {
    if (parent.children[i].isEqualNode(elm)) {
        return i;
    }
  }
}
function startTemplate() {
    var i;
    var navItems = document.querySelectorAll("#navigation button");
    for (i = 0; i < navItems.length; i++) {
        navItems[i].addEventListener("click", navButtonClick);
    }
}
startTemplate();

JSFiddle

<script>
function navButtonClick(index) {
    return function (ev) {
         document.getElementById("output").innerHTML = index;
    }
}
function startTemplate() {
    var i;
    var navItems = document.querySelectorAll("#navigation button");
    for (i=0; i < navItems.length; i++) {
        navItems[i].addEventListener("click", navButtonClick(i));
    }
}
document.addEventListener("DOMContentLoaded", startTemplate);
</script>

希望,它:)工作

无论如何,仅适用于按钮(即使对于它们,我也需要在 chrome 中closest)。

document.addEventListener('click', function (event) {
  var target = event.target, nodes, i;
  
  if (target.closest) {
    target = target.closest('button');
  }
                                                     
  if (target && target.tagName === 'BUTTON') {
    nodes = target.parentElement.children; 
    for (i=0; nodes[i]!==target; ++i);
    document.querySelector("output").textContent = i;
  }
})
<nav id="navigation" role="navigation">
  <button type="button"> <em>Navi tab 1</em> </button>
  <button type="button"> Navi tab 2 </button>
  <button type="button"> Navi tab 3 </button>
  <button type="button"> Navi tab 4 </button>
</nav>
<output></output>

ES6 风格的答案:

const indexOf = element => Array.from(element.parentNode.children).indexOf(element)
const buttonIndex = indexOf(event.currentTarget)