map<T> 方法

Iterable<T> map<T>(
  1. T f(
    1. E element
    )
)
override

通过 toElement 方法修改当前可迭代对象的元素。

返回一个新的懒udge Iterable,其元素是通过调用此 Iterable 的每个元素在迭代顺序上的 toElement 方法创建的。

返回的可迭代对象是懒性的,因此它不会在自身迭代之前迭代此可迭代对象的元素,然后在迭代时逐个应用 toElement 以创建一个元素。转换后的元素不会被缓存。多次迭代返回的 Iterable 将会为每个元素在每次迭代中调用一次提供的 toElement 函数。

返回的可迭代对象上的方法可以跳过调用 toElement,在这些情况下结果不需要。例如,elementAt 可能只调用一次 toElement

相当于

Iterable<T> map<T>(T toElement(E e)) sync* {
  for (var value in this) {
    yield toElement(value);
  }
}

示例

var products = jsonDecode('''
[
  {"name": "Screwdriver", "price": 42.00},
  {"name": "Wingnut", "price": 0.50}
]
''');
var values = products.map((product) => product['price'] as double);
var totalPrice = values.fold(0.0, (a, b) => a + b); // 42.5.

实现

Iterable<T> map<T>(T f(E element)) => MappedListIterable<E, T>(this, f);