map()函数内部的索引

2020/10/03 21:41 · javascript ·  · 0评论

我缺少一个选项,如何map使用Listfrom获取函数内部的索引号Immutable.js

var list2 = list1.map(mapper => { a: mapper.a, b: mapper.index??? }).toList();

文档显示的是map()回报Iterable<number, M>有什么优雅的方式可以满足我的需求吗?

您将能够通过其第二个参数index获得该map方法的当前迭代

例:

const list = [ 'h', 'e', 'l', 'l', 'o'];
list.map((currElement, index) => {
  console.log("The current iteration is: " + index);
  console.log("The current element is: " + currElement);
  console.log("\n");
  return currElement; //equivalent to list[index]
});

输出:

The current iteration is: 0 <br>The current element is: h

The current iteration is: 1 <br>The current element is: e

The current iteration is: 2 <br>The current element is: l

The current iteration is: 3 <br>The current element is: l 

The current iteration is: 4 <br>The current element is: o

另请参阅: https : //developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array/map

参量

callback-产生新Array元素的函数,带有三个参数:

1)currentValue

数组中正在处理的当前元素。

2)index

数组中正在处理的当前元素的索引。

3)数组

调用了数组映射。

Array.prototype.map() 指数:

可以Array.prototype.map()通过回调函数的第二个参数访问索引这是一个例子:

const array = [1, 2, 3, 4];


const map = array.map((x, index) => {
  console.log(index);
  return x + index;
});

console.log(map);

其他论点Array.prototype.map()

  • 回调函数的第三个参数公开了在其上调用了map的数组
  • 的第二个参数Array.map()是一个对象,它将是this回调函数值。请记住,由于箭头函数没有与关键字的绑定,因此必须使用常规function关键字来声明回调this

例如:

const array = [1, 2, 3, 4];

const thisObj = {prop1: 1}


const map = array.map( function (x, index, array) {
  console.log(array);
  console.log(this)
}, thisObj);

使用Ramda:

import {addIndex, map} from 'ramda';

const list = [ 'h', 'e', 'l', 'l', 'o'];
const mapIndexed = addIndex(map);
mapIndexed((currElement, index) => {
  console.log("The current iteration is: " + index);
  console.log("The current element is: " + currElement);
  console.log("\n");
  return 'X';
}, list);
本文地址:http://javascript.askforanswer.com/maphanshuneibudesuoyin.html
文章标签: ,   ,  
版权声明:本文为原创文章,版权归 javascript 所有,欢迎分享本文,转载请保留出处!

文件下载

老薛主机终身7折优惠码boke112

上一篇:
下一篇:

评论已关闭!