12/08/2018, 18:13

Top 10 Array (List) method trong dart nên biết

1.forEach(void f(E element)) → void Thực thi hàm f cho từng phần tử trong list 2.map<T>(T f(E e)) → Iterable<T> Trả về một Iterable mới, sau khi transform từng phần bằng hàm f 3.contains(Object element) → bool Trả về true nếu trong list có chứa phần tử bằng ...

1.forEach(void f(E element)) → void

Thực thi hàm f cho từng phần tử trong list

2.map<T>(T f(E e)) → Iterable<T>

Trả về một Iterable mới, sau khi transform từng phần bằng hàm f

3.contains(Object element) → bool

Trả về true nếu trong list có chứa phần tử bằng element (sử dụng phương thức Object.== để kiểm tra) Trong ví dụ bên dưới, ta phải override hashCode và operator ==

4.sort([int compare(E a, E b) ]) → void

Sắp xếp list theo thứ tự được xác định bởi hàm compare (nếu compare bị bỏ qua thì sẽ sử dụng Comparable.compare)

5.reduce(E combine(E value, E element)) → E

và fold<T>(T initialValue, T combine(T previousValue, E element)) → T

Reduce các phần tử của list thành một giá trị duy nhất, sử dụng hàm combine

  • Reduce: trả về giá trị có kiểu là kiểu của phần tử trong list. Nếu list rỗng thì sẽ throw IterableElementError.noElement();
  • Fold: cho phép cung cấp giá trị ban đầu initialValue và trả về giá trị có kiểu có kiểu tùy ý, không nhất thiết phải giống với kiểu của các phần tử trong list. Nếu list rỗng thì sẽ trả về initialValue

6.every(bool f(E element)) → bool

Kiểm tra xem mọi phần tử trong list có thỏa mãn hàm f hay không

7.where(bool test(E element)) → Iterable<E>

firstWhere(bool test(E element), { E orElse() }) → E

lastWhere(bool test(E element), { E orElse() }) → E

singleWhere(bool test(E element)) → E

  • Where (trong các ngôn ngữ khac thường gọi là filter): trả về một Iterable mới, mà tất cả các phần tử thỏa mãn hàm test
  • FirstWhere: trả về phần tử đầu tiên thỏa mãn hàm test. Nếu không có phần tử thỏa mãn, trả về orElse(), nếu orElse bị bỏ qua, throw IterableElementError.noElement();
  • LastWhere: tương tự firstWhere, nhưng trả về phần tử cuối
  • SingleWhere: trả về một phần tử thòa mãn hàm test. Nếu không có hoặc có nhiều hơn một phần tử thỏa mãn sẽ throw StateError

8.take(int count) → Iterable<E>

và skip(int count) → Iterable<E>

  • Take: trả về Iterable mới của count phần tử đầu tiên
  • Skip: trả về Iterable mới bỏ qua count phần tử đầu tiên

9.List.from(Iterable elements, { bool growable: true })

Tạo list mới chứa tất cả các phần tử của elements

10.expand<T>(Iterable<T> f(E element)) → Iterable<T>

Expands mỗi phần tử thành không hoặc nhiều phần tử (trong các ngôn ngữ khac thường gọi là flatMap)

0