如何获取getElementsByClassName()数组的下标?

比如,我用getElementsByClassName()获取了5个标签,我又用this控制了其中第二个标签,如何获取this所指向标签在getElementsByClassName()数组中的位置?

阅读 8k
2 个回答

更正一个错误,getElementsByClassName() 拿到的结果并不是数组,而 HTMLCollection 对象。

const elements = Array.from(document.getElementsByClassName('.class-name'));

// const elements = Array.prototype.slice.apply(document.getElementsByClassName('.class-name'));

const that = elements[3];

console.log(elements.indexOf(that));

思路是将获取到的 HTMLCollection 对象转换为数组,再使用数组的 indexOf() 方法获取指定元素的索引。

可以设置this.index

`for(var i=0;i<elsEments.length;i++){
    elsEments[i].index=i;
}

this.index就是这个元素的下标
`

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题