根据另一个数组的索引获取一个数组的值
Get the value of one array according to another arrays index
我试图通过使用array2的索引来获得array1内的数值值。例如,我的数组是这样的:
const array1 = ["3","4","5","6","7","8"];
const array2 = ["bat","cat","dog","fish","cow","bird"];
如果用户选择"cat"
,它应该抓取"4"
。
array2.forEach(animal => {
console.log(array1.indexOf(animal)); // returns -1
});
我怎样才能使它工作?
将array2
的当前索引传递给forEach
回调(第二个参数)
const array1 = ["3","4","5","6","7","8"];
const array2 = ["bat","cat","dog","fish","cow","bird"];
array2.forEach((animal, i) => {
console.log(array1[i]);
});
只需使用括号符号和indexOf
const array1 = ["3","4","5","6","7","8"];
const array2 = ["bat","cat","dog","fish","cow","bird"];
let choice = 'cat'; // user selection
let result = array1[array2.indexOf(choice)]; // grab value
alert(result);
你的代码需要修改。
据我所知有两个条件。第一种方法是获取动物名称并在array1中搜索相关索引。第二种方法是在array2上循环,然后在array1中得到相关的项。
//First condition
var animalName = 'XXX'; // You get this from the user.
var indexOfAnimal = array2.indexOf(animalName);
var relatedItem = array1[indexOfAnimal];
//Second condition
foreach(var index in array2){
console.log(array1[index]);
}
//Your code with changes
array2.forEach(animal => {
var indexOfAnimal = array2.indexOf(animal);
console.log(array1[indexOfAnimal]);
});
相关文章:
- Javascript(Angular)从一个对象数组到第二个数组查找值
- 根据id将json数组组合为一个json数组
- JavaScript数组包含一个值
- 对一个对象使用reduce可以返回一个没有't在数组中包含目标字母
- jQuery$.inArray()总是返回-1和一个对象数组
- 在数组中的一个元素上设置多个值
- javascript处理一个对象数组以获得一个新的对象数组
- 作为一个二维数组,从ajax接收
- 你能用来自数组的属性名称生成一个对象吗
- 多维关联数组的最后一个索引
- 如何创建一个方法来验证数组的范围
- 循环以检查数组中的最后一个图像
- 在Javascript中将一个值和字符串数组转换为if语句
- 算法:从数组(javascript/angular)中按当前日期获取上一个和下一个事件
- 如何将一个对象添加到每个对象数组中
- 如何创建一个谷歌地图地理坐标数组
- 如何从另一个带下划线的数组中筛选带元素的数组
- 使用window.location.htm和匹配的URL数组(一个用于桌面,一个用于移动)将桌面网站重定向到移动
- Javascript排序多维数组-一个完整的例子
- 刽子手的游戏.2数组.一个需要相应地更新另一个