Javascript đếm số lần xuất hiện trong mảng đối tượng
Cú pháp gán phá hủy là một biểu thức JavaScript cho phép giải nén các giá trị từ mảng hoặc thuộc tính từ các đối tượng thành các biến riêng biệt. Thay vì gắn bó với biến đối tượng hiện có, chúng ta có thể đổi tên chúng theo sở thích của riêng mình Show
Trong bài viết này, chúng ta sẽ tìm hiểu cách đếm theo các thuộc tính của một mảng các đối tượng chỉ sử dụng một dòng mã trong JavaScript. Đây là đoạn mã JavaScript một dòng sử dụng một trong những tính năng phổ biến nhất của ES6 => Hãy xác định chức năng ngắn này Giả sử sau đây là mảng của chúng ta - var details = [ { studentName: "John", studentAge: 23 }, { studentName: "David", studentAge: 24 }, { studentName: "John", studentAge: 21 }, { studentName: "John", studentAge: 25 }, { studentName: "Bob", studentAge: 22 }, { studentName: "David", studentAge: 20 } ] Chúng ta cần đếm số lần xuất hiện của các tên lặp đi lặp lại i. e. đầu ra phải là John: 3 David: 2 Bob: 1 Đối với điều này, bạn có thể sử dụng khái niệm giảm() Thí dụSau đây là mã - var details = [ { studentName: "John", studentAge: 23 }, { studentName: "David", studentAge: 24 }, { studentName: "John", studentAge: 21 }, { studentName: "John", studentAge: 25 }, { studentName: "Bob", studentAge: 22 }, { studentName: "David", studentAge: 20 } ] var output = Object.values(details.reduce((obj, { studentName }) => { if (obj[studentName] === undefined) obj[studentName] = { studentName: studentName, occurrences: 1 }; else obj[studentName].occurrences++; return obj; }, {})); console.log(output); Để chạy chương trình trên, bạn cần sử dụng lệnh sau - node fileName.js. Ở đây, tên tệp của tôi là demo282. js. Điều này sẽ tạo ra đầu ra sau trên bảng điều khiển - PS C:\Users\Amit\javascript-code> node demo282.js [ { studentName: 'John', occurrences: 3 }, { studentName: 'David', occurrences: 2 }, { studentName: 'Bob', occurrences: 1 } ] Biết cách lặp nhanh qua một mảng và đếm các đối tượng rất đơn giản. Phương thức 0 sẽ cho bạn biết tổng số giá trị trong mảng, nhưng nếu bạn chỉ muốn đếm những giá trị đó dựa trên các điều kiện nhất định thì sao?Ví dụ, hãy tưởng tượng bạn có một mảng như thế này
Và bạn chỉ muốn đếm số đối tượng có ____6_______1 được đặt thành ____6_______2 Giống như mọi thứ trong lập trình, có một số cách để làm điều này. Chúng ta sẽ đi qua một số phương pháp phổ biến dưới đây Sử dụng vòng lặp const storage = [ { data: '1', status: '0' }, { data: '2', status: '0' }, { data: '3', status: '0' }, { data: '4', status: '0' }, { data: '5', status: '0' }, { data: '6', status: '0' }, { data: '7', status: '1' }, ]; let counter = 0; for (let i = 0; i < storage.length; i++) { if (storage[i].status === '0') counter++; } console.log(counter); // 63Có lẽ cách dễ nhất là khai báo một biến 4, lặp qua mảng và lặp lại 4 chỉ khi 1 bằng với 2
Bạn có thể đơn giản hóa điều này một chút bằng cách sử dụng vòng lặp 8
Ngoài ra, bạn có thể tạo một hàm để làm điều tương tự nếu bạn có các mảng đối tượng khác để đếm theo điều kiện
Sử dụng các phương thức mảngJavaScript bao gồm một loạt các phương thức hữu ích khi làm việc với mảng. Mỗi cái có thể được xâu chuỗi thành một mảng và truyền các tham số khác nhau để làm việc trong khi lặp qua các phần tử trong mảng Hai cái chúng ta sẽ xem xét là 9 và 0const storage = [ { data: '1', status: '0' }, { data: '2', status: '0' }, { data: '3', status: '0' }, { data: '4', status: '0' }, { data: '5', status: '0' }, { data: '6', status: '0' }, { data: '7', status: '1' }, ]; let counter = 0; for (let i = 0; i < storage.length; i++) { if (storage[i].status === '0') counter++; } console.log(counter); // 69Phương thức bộ lọc thực hiện điều đó – nó lặp qua từng phần tử trong mảng và lọc ra tất cả các phần tử không đáp ứng (các) điều kiện mà bạn cung cấp. Sau đó, nó trả về một mảng mới với tất cả các phần tử trả về true dựa trên (các) điều kiện của bạn Ví dụ
Bây giờ bạn đã lọc ra đối tượng có 2, chỉ cần gọi phương thức 0 trên mảng mới để lấy tổng số đối tượng có 2
Nhưng điều này có thể được rút ngắn rất nhiều với cú pháp ES6
const storage = [ { data: '1', status: '0' }, { data: '2', status: '0' }, { data: '3', status: '0' }, { data: '4', status: '0' }, { data: '5', status: '0' }, { data: '6', status: '0' }, { data: '7', status: '1' }, ]; let counter = 0; for (const obj of storage) { if (obj.status === '0') counter++; } console.log(counter); // 60Hãy coi phương thức 0 giống như một con dao của quân đội Thụy Sĩ – nó cực kỳ linh hoạt và cho phép bạn lấy một mảng làm đầu vào và chuyển đổi nó thành bất kỳ thứ gì. Thậm chí tốt hơn, như 9, phương thức này trả về một mảng mới, giữ nguyên mảng ban đầuBạn có thể đọc thêm về 0 trong bài viết nàyĐối với mục đích của chúng tôi, chúng tôi muốn lấy một mảng, kiểm tra nội dung của nó và tạo ra một số. Đây là một cách đơn giản để làm điều đó
Bạn có thể đơn giản hóa hơn nữa bằng cách sử dụng cú pháp ES6 và toán tử bậc ba
Và thậm chí nhiều hơn một chút bằng cách sử dụng phá hủy đối tượng
Vì vậy, đó là một số cách để duyệt qua các phần tử của một mảng và đếm chúng theo điều kiện. Bây giờ hãy ra khỏi đó và đếm với sự tự tin QUẢNG CÁO QUẢNG CÁO QUẢNG CÁO Nếu bài viết này hữu ích, hãy tweet nó Học cách viết mã miễn phí. Chương trình giảng dạy mã nguồn mở của freeCodeCamp đã giúp hơn 40.000 người có được việc làm với tư cách là nhà phát triển. Bắt đầu Làm cách nào để đếm số lần xuất hiện của một phần tử trong một mảng trong JavaScript?Để đếm số lần xuất hiện của phần tử trong một mảng, hãy sử dụng phương thức “filter()” với thuộc tính “length”, phương thức “reduce()”, vòng lặp “for” hoặc . .
Làm cách nào để đếm số lần xuất hiện trong JavaScript?Trong JavaScript, chúng ta có thể đếm số lần xuất hiện của chuỗi trong một chuỗi bằng cách đếm số lần chuỗi xuất hiện trong chuỗi . JavaScript cung cấp một hàm match(), được sử dụng để tạo ra tất cả các lần xuất hiện của một chuỗi trong một mảng.
Làm cách nào để kiểm tra sự xuất hiện của một phần tử trong một mảng trong JavaScript?Trong đoạn mã trên, chúng tôi đã sử dụng thư viện JavaScript lodash chấp nhận một mảng và kiểm tra sự xuất hiện của từng phần tử trong mảng. Các. Phương thức CountBy() của Lodash lấy các giá trị của mảng JS và trả về một đối tượng mới . Đối tượng bao gồm từng phần tử và số lượng của nó trong các cặp khóa-giá trị.
Làm cách nào để đếm các giá trị trùng lặp trong một mảng đối tượng trong JavaScript?Đếm số trùng lặp trong một mảng bằng JavaScript . Để đếm các bản sao trong một mảng Sử dụng phương thức reduce() để đếm các bản sao trong một mảng, truyền cho nó một đối tượng trống làm giá trị ban đầu cho bộ tích lũy. . Bất cứ thứ gì chúng ta trả về từ hàm gọi lại đều được chuyển thành bộ tích lũy trong lần lặp tiếp theo |