Javascript数组过滤器不过滤 [英] Javascript Array filter not filtering
问题描述
我无法让Javascript过滤动态创建的数组,尽管它可以很好地过滤静态数组。代码块#1工作(静态数组),代码块#2不工作(动态创建数组):
I cannot get Javascript to filter a dynamically created array, although it filters a static array fine. Code block #1 works (static array), code block #2 doesn't (dynamically created array):
// global variables
var globalCalendarEventsArray = [
{element: "box1", unit: "a"},
{element: "box2", unit: "a"},
{element: "box3", unit: "b"},
{element: "box4", unit: "b"}
];
// var globalCalendarEventsArray = document.getElementsByClassName("redBox");
var rowCalendarEventsArray = [];
// functions
function getRowCalendarEvents (_eventsArray,_unitValue) {
return _eventsArray.filter(function(_calendarEvent) {
return _calendarEvent.unit == _unitValue;
});
}
function onMouseDblClick () {
rowCalendarEventsArray = getRowCalendarEvents(globalCalendarEventsArray,"a");
alert(globalCalendarEventsArray.length);
alert(globalCalendarEventsArray[0].unit);
alert (rowCalendarEventsArray.length);
}
// event listeners
window.addEventListener("dblclick",onMouseDblClick,false);
// execution code
var box1 = document.createElement("div");
box1.className = "redBox";
box1.unit = "a";
document.body.appendChild(box1);
var box2 = document.createElement("div");
box2.className = "redBox";
box2.unit = "a";
document.body.appendChild(box2);
var box3 = document.createElement("div");
box3.className = "redBox";
box3.unit = "b";
document.body.appendChild(box3);
var box4 = document.createElement("div");
box4.className = "redBox";
box4.unit = "b";
document.body.appendChild(box4);
然而,只要我使用.getElementsByClassName动态构建数组,尽管过滤仍然分崩离析,尽管警报函数确认.getElementsByClassName构建了一个数组,当我调用.unit属性时它就在那里。例如:
However, as soon as I build the array dynamically by using .getElementsByClassName, the filtering falls apart, despite the alert functions confirming that .getElementsByClassName built an array and that when I call the .unit property it is there. Ex:
// global variables
/*
var globalCalendarEventsArray = [
{element: "box1", unit: "a"},
{element: "box2", unit: "a"},
{element: "box3", unit: "b"},
{element: "box4", unit: "b"}
];*/
var globalCalendarEventsArray = document.getElementsByClassName("redBox");
var rowCalendarEventsArray = [];
// functions
function getRowCalendarEvents (_eventsArray,_unitValue) {
return _eventsArray.filter(function(_calendarEvent) {
return _calendarEvent.unit == _unitValue;
});
}
function onMouseDblClick () {
rowCalendarEventsArray = getRowCalendarEvents(globalCalendarEventsArray,"a");
alert(globalCalendarEventsArray.length);
alert(globalCalendarEventsArray[0].unit);
alert (rowCalendarEventsArray.length);
}
// event listeners
window.addEventListener("dblclick",onMouseDblClick,false);
// execution code
var box1 = document.createElement("div");
box1.className = "redBox";
box1.unit = "a";
document.body.appendChild(box1);
var box2 = document.createElement("div");
box2.className = "redBox";
box2.unit = "a";
document.body.appendChild(box2);
var box3 = document.createElement("div");
box3.className = "redBox";
box3.unit = "b";
document.body.appendChild(box3);
var box4 = document.createElement("div");
box4.className = "redBox";
box4.unit = "b";
document.body.appendChild(box4);
小提琴: https://jsfiddle.net/kryman/uexo1hs4/
任何帮助将不胜感激,谢谢。
Any help would be appreciated, thank you.
推荐答案
_eventsArray
在你的第二个例子中是HTMLCollection而不是JS数组。您可以将其转换为如下所示:
_eventsArray
in your second example is an HTMLCollection not a JS Array. You can convert it like the following:
function getRowCalendarEvents (_eventsArray,_unitValue) {
var arr = [].slice.call(_eventsArray);
return arr.filter(function(_calendarEvent) {
return _calendarEvent.unit == _unitValue;
});
}
这篇关于Javascript数组过滤器不过滤的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!