From fb38bd2971276b24f58a91a15b8f34a923f0e024 Mon Sep 17 00:00:00 2001 From: I_am_Vietnam <91591390+ImVietnam@users.noreply.github.com> Date: Tue, 7 Mar 2023 18:52:22 +0700 Subject: [PATCH 1/7] Update article.md --- .../09-keys-values-entries/article.md | 64 +++++++++---------- 1 file changed, 32 insertions(+), 32 deletions(-) diff --git a/1-js/05-data-types/09-keys-values-entries/article.md b/1-js/05-data-types/09-keys-values-entries/article.md index b633dc274..2feaad89b 100644 --- a/1-js/05-data-types/09-keys-values-entries/article.md +++ b/1-js/05-data-types/09-keys-values-entries/article.md @@ -1,42 +1,42 @@ # Object.keys, values, entries -Let's step away from the individual data structures and talk about the iterations over them. +Hãy bỏ qua các cấu trúc dữ liệu riêng lẻ và nói về các lần lặp lại trên chúng. -In the previous chapter we saw methods `map.keys()`, `map.values()`, `map.entries()`. +Trong chương trước chúng ta đã thấy các phương thức `map.keys()`, `map.values()`, `map.entries()`. -These methods are generic, there is a common agreement to use them for data structures. If we ever create a data structure of our own, we should implement them too. +Các phương pháp này là chung chung, có một thỏa thuận chung để sử dụng chúng cho các cấu trúc dữ liệu. Nếu chúng ta từng tạo cấu trúc dữ liệu của riêng mình, chúng ta cũng nên triển khai chúng. -They are supported for: +Chúng được hỗ trợ cho: - `Map` - `Set` - `Array` -Plain objects also support similar methods, but the syntax is a bit different. +Các đối tượng đơn giản cũng hỗ trợ các phương thức tương tự, nhưng cú pháp hơi khác một chút. ## Object.keys, values, entries -For plain objects, the following methods are available: +Đối với các đối tượng đơn giản, có các phương thức sau: -- [Object.keys(obj)](mdn:js/Object/keys) -- returns an array of keys. -- [Object.values(obj)](mdn:js/Object/values) -- returns an array of values. -- [Object.entries(obj)](mdn:js/Object/entries) -- returns an array of `[key, value]` pairs. +- [Object.keys(obj)](mdn:js/Object/keys) -- trả về một array khóa. +- [Object.values(obj)](mdn:js/Object/values) -- trả về một array giá trị. +- [Object.entries(obj)](mdn:js/Object/entries) -- trả về một array các cặp `[key, value]`. -Please note the distinctions (compared to map for example): +Hãy lưu ý các điểm khác biệt (ví dụ so với map): -| | Map | Object | -|-------------|------------------|--------------| -| Call syntax | `map.keys()` | `Object.keys(obj)`, but not `obj.keys()` | -| Returns | iterable | "real" Array | +| | Map | Đối tượng | +|---------------------|------------------|--------------| +| Cú pháp gọi | `map.keys()` | `Object.keys(obj)`, chứ không phải `obj.keys()` | +| Trả lại | iterable | Array "thực" | -The first difference is that we have to call `Object.keys(obj)`, and not `obj.keys()`. +Sự khác biệt đầu tiên là chúng ta phải gọi `Object.keys(obj)`, chứ không phải `obj.keys()`. -Why so? The main reason is flexibility. Remember, objects are a base of all complex structures in JavaScript. So we may have an object of our own like `data` that implements its own `data.values()` method. And we still can call `Object.values(data)` on it. +Tại sao như vậy? Lý do chính là tính linh hoạt. Hãy nhớ rằng, các đối tượng là cơ sở của tất cả các cấu trúc phức tạp trong JavaScript. Vì vậy, chúng ta có thể có một đối tượng của riêng mình như `data` thực hiện phương thức `data.values()` của chính nó. Và chúng ta vẫn có thể gọi `Object.values(data)` trên đó. -The second difference is that `Object.*` methods return "real" array objects, not just an iterable. That's mainly for historical reasons. +Điểm khác biệt thứ hai là các phương thức `Object.*` trả về các đối tượng array "thực", không chỉ là một đối tượng iterable. Đó chủ yếu là vì lý do lịch sử. -For instance: +Ví dụ: ```js let user = { @@ -49,7 +49,7 @@ let user = { - `Object.values(user) = ["John", 30]` - `Object.entries(user) = [ ["name","John"], ["age",30] ]` -Here's an example of using `Object.values` to loop over property values: +Đây là một ví dụ về việc sử dụng `Object.values` để lặp qua các giá trị thuộc tính: ```js run let user = { @@ -57,30 +57,30 @@ let user = { age: 30 }; -// loop over values +// lặp lại các giá trị for (let value of Object.values(user)) { alert(value); // John, then 30 } ``` -```warn header="Object.keys/values/entries ignore symbolic properties" -Just like a `for..in` loop, these methods ignore properties that use `Symbol(...)` as keys. +```warn header="Object.keys/values/entries bỏ qua các thuộc tính tượng trưng" +Giống như vòng lặp `for..in`, các phương thức này bỏ qua các thuộc tính sử dụng `Symbol(...)` làm khóa. -Usually that's convenient. But if we want symbolic keys too, then there's a separate method [Object.getOwnPropertySymbols](mdn:js/Object/getOwnPropertySymbols) that returns an array of only symbolic keys. Also, there exist a method [Reflect.ownKeys(obj)](mdn:js/Reflect/ownKeys) that returns *all* keys. +Thông thường đó là thuận tiện. Nhưng nếu chúng ta cũng muốn có các khóa tượng trưng, thì có một phương thức riêng [Object.getOwnPropertySymbols](mdn:js/Object/getOwnPropertySymbols) trả về một array chỉ các khóa tượng trưng. Ngoài ra, tồn tại một phương thức [Reflect.ownKeys(obj)](mdn:js/Reflect/ownKeys) trả về các khóa *tất cả*. ``` -## Transforming objects +## Chuyển đổi đối tượng -Objects lack many methods that exist for arrays, e.g. `map`, `filter` and others. +Các đối tượng thiếu nhiều phương thức tồn tại cho array, ví dụ: `map`, `filter` và những thứ khác. -If we'd like to apply them, then we can use `Object.entries` followed by `Object.fromEntries`: +Nếu chúng ta muốn áp dụng chúng, thì chúng ta có thể sử dụng `Object.entries` theo sau là `Object.fromEntries`: -1. Use `Object.entries(obj)` to get an array of key/value pairs from `obj`. -2. Use array methods on that array, e.g. `map`. -3. Use `Object.fromEntries(array)` on the resulting array to turn it back into an object. +1. Sử dụng `Object.entries(obj)` để lấy một array các cặp khóa/giá trị từ `obj`. +2. Sử dụng các phương thức array trên array đó, ví dụ `map`. +3. Sử dụng `Object.fromEntries(array)` trên array kết quả để biến nó trở lại thành một đối tượng. -For example, we have an object with prices, and would like to double them: +Ví dụ: chúng ta có một đối tượng có giá và muốn nhân đôi chúng: ```js run let prices = { @@ -91,7 +91,7 @@ let prices = { *!* let doublePrices = Object.fromEntries( - // convert to array, map, and then fromEntries gives back the object + // chuyển đổi thành array, map và sau đó fromEntries trả lại đối tượng Object.entries(prices).map(([key, value]) => [key, value * 2]) ); */!* @@ -99,4 +99,4 @@ let doublePrices = Object.fromEntries( alert(doublePrices.meat); // 8 ``` -It may look difficult from the first sight, but becomes easy to understand after you use it once or twice. We can make powerful chains of transforms this way. +Nó có thể trông khó khăn ngay từ cái nhìn đầu tiên, nhưng sẽ trở nên dễ hiểu sau khi bạn sử dụng nó một hoặc hai lần. Chúng ta có thể tạo ra những chuỗi biến đổi mạnh mẽ theo cách này. From 7829c8bb301922abab04d093af5aadf9740d2448 Mon Sep 17 00:00:00 2001 From: I_am_Vietnam <91591390+ImVietnam@users.noreply.github.com> Date: Tue, 7 Mar 2023 18:53:14 +0700 Subject: [PATCH 2/7] Update task.md --- .../09-keys-values-entries/01-sum-salaries/task.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/task.md b/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/task.md index 211357d03..b19c4a14d 100644 --- a/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/task.md +++ b/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/task.md @@ -2,15 +2,15 @@ importance: 5 --- -# Sum the properties +# Tính tổng các thuộc tính -There is a `salaries` object with arbitrary number of salaries. +Có một đối tượng `salaries` với số lương tùy ý. -Write the function `sumSalaries(salaries)` that returns the sum of all salaries using `Object.values` and the `for..of` loop. +Viết hàm `sumSalary(salaries)` trả về tổng của tất cả các khoản lương bằng cách sử dụng `Object.values` và vòng lặp `for..of`. -If `salaries` is empty, then the result must be `0`. +Nếu `salaries` trống, thì kết quả phải là `0`. -For instance: +Ví dụ: ```js let salaries = { From d8f01addb3f2e41527e3a5a05e27adaa7d2c1c79 Mon Sep 17 00:00:00 2001 From: I_am_Vietnam <91591390+ImVietnam@users.noreply.github.com> Date: Tue, 7 Mar 2023 18:53:55 +0700 Subject: [PATCH 3/7] Update solution.md --- .../09-keys-values-entries/01-sum-salaries/solution.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/solution.md b/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/solution.md index 27a7b418a..1a8b51525 100644 --- a/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/solution.md +++ b/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/solution.md @@ -17,12 +17,12 @@ let salaries = { alert( sumSalaries(salaries) ); // 650 ``` -Or, optionally, we could also get the sum using `Object.values` and `reduce`: +Hoặc, theo tùy chọn, chúng ta cũng có thể lấy tổng bằng cách sử dụng `Object.values` và `reduce`: ```js -// reduce loops over array of salaries, -// adding them up -// and returns the result +// giảm các vòng lặp trên array tiền lương, +// thêm chúng lên +// và trả về kết quả function sumSalaries(salaries) { return Object.values(salaries).reduce((a, b) => a + b, 0) // 650 } From fd4f5e71c8884566f7f6f95416044cf7e2b1b4bb Mon Sep 17 00:00:00 2001 From: I_am_Vietnam <91591390+ImVietnam@users.noreply.github.com> Date: Tue, 7 Mar 2023 18:54:49 +0700 Subject: [PATCH 4/7] Update task.md --- .../09-keys-values-entries/02-count-properties/task.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/1-js/05-data-types/09-keys-values-entries/02-count-properties/task.md b/1-js/05-data-types/09-keys-values-entries/02-count-properties/task.md index d7aebb1fa..158538a85 100644 --- a/1-js/05-data-types/09-keys-values-entries/02-count-properties/task.md +++ b/1-js/05-data-types/09-keys-values-entries/02-count-properties/task.md @@ -2,9 +2,9 @@ importance: 5 --- -# Count properties +# Đếm thuộc tính -Write a function `count(obj)` that returns the number of properties in the object: +Viết hàm `count(obj)` trả về số thuộc tính trong đối tượng: ```js let user = { @@ -15,7 +15,7 @@ let user = { alert( count(user) ); // 2 ``` -Try to make the code as short as possible. +Cố gắng làm cho mã càng ngắn càng tốt. -P.S. Ignore symbolic properties, count only "regular" ones. +Tái bút: Bỏ qua các thuộc tính tượng trưng, chỉ tính những thuộc tính "thông thường". From d7ad7128ab10035e192c48268f3a2fce08d9deea Mon Sep 17 00:00:00 2001 From: I_am_Vietnam <91591390+ImVietnam@users.noreply.github.com> Date: Tue, 13 Jun 2023 10:58:57 +0700 Subject: [PATCH 5/7] Update solution.md --- .../09-keys-values-entries/01-sum-salaries/solution.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/solution.md b/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/solution.md index 1a8b51525..7500b8b50 100644 --- a/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/solution.md +++ b/1-js/05-data-types/09-keys-values-entries/01-sum-salaries/solution.md @@ -21,7 +21,7 @@ Hoặc, theo tùy chọn, chúng ta cũng có thể lấy tổng bằng cách s ```js // giảm các vòng lặp trên array tiền lương, -// thêm chúng lên +// thêm chúng // và trả về kết quả function sumSalaries(salaries) { return Object.values(salaries).reduce((a, b) => a + b, 0) // 650 From 6ccef5196b33227a94d6cd9acfbcb360c7c9f1b5 Mon Sep 17 00:00:00 2001 From: I_am_Vietnam <91591390+ImVietnam@users.noreply.github.com> Date: Tue, 13 Jun 2023 11:05:24 +0700 Subject: [PATCH 6/7] some fixes --- 1-js/05-data-types/09-keys-values-entries/article.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/1-js/05-data-types/09-keys-values-entries/article.md b/1-js/05-data-types/09-keys-values-entries/article.md index 2feaad89b..c22eaf846 100644 --- a/1-js/05-data-types/09-keys-values-entries/article.md +++ b/1-js/05-data-types/09-keys-values-entries/article.md @@ -19,9 +19,9 @@ Các đối tượng đơn giản cũng hỗ trợ các phương thức tương Đối với các đối tượng đơn giản, có các phương thức sau: -- [Object.keys(obj)](mdn:js/Object/keys) -- trả về một array khóa. -- [Object.values(obj)](mdn:js/Object/values) -- trả về một array giá trị. -- [Object.entries(obj)](mdn:js/Object/entries) -- trả về một array các cặp `[key, value]`. +- [Object.keys(obj)](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/keys) -- trả về một array khóa. +- [Object.values(obj)](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/values) -- trả về một array giá trị. +- [Object.entries(obj)](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/entries) -- trả về một array các cặp `[key, value]`. Hãy lưu ý các điểm khác biệt (ví dụ so với map): @@ -66,7 +66,7 @@ for (let value of Object.values(user)) { ```warn header="Object.keys/values/entries bỏ qua các thuộc tính tượng trưng" Giống như vòng lặp `for..in`, các phương thức này bỏ qua các thuộc tính sử dụng `Symbol(...)` làm khóa. -Thông thường đó là thuận tiện. Nhưng nếu chúng ta cũng muốn có các khóa tượng trưng, thì có một phương thức riêng [Object.getOwnPropertySymbols](mdn:js/Object/getOwnPropertySymbols) trả về một array chỉ các khóa tượng trưng. Ngoài ra, tồn tại một phương thức [Reflect.ownKeys(obj)](mdn:js/Reflect/ownKeys) trả về các khóa *tất cả*. +Thông thường đó là thuận tiện. Nhưng nếu chúng ta cũng muốn có các khóa tượng trưng, thì có một phương thức riêng [Object.getOwnPropertySymbols](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/getOwnPropertySymbols) trả về một array chỉ các khóa tượng trưng. Ngoài ra, tồn tại một phương thức [Reflect.ownKeys(obj)](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Reflect/ownKeys) trả về các khóa *tất cả*. ``` From 5c927e3c3ff1d1be342b6913be9eb6f267513563 Mon Sep 17 00:00:00 2001 From: I_am_Vietnam <91591390+ImVietnam@users.noreply.github.com> Date: Tue, 13 Jun 2023 11:08:44 +0700 Subject: [PATCH 7/7] sync with en version --- 1-js/05-data-types/09-keys-values-entries/article.md | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/1-js/05-data-types/09-keys-values-entries/article.md b/1-js/05-data-types/09-keys-values-entries/article.md index c22eaf846..20f0cf4e6 100644 --- a/1-js/05-data-types/09-keys-values-entries/article.md +++ b/1-js/05-data-types/09-keys-values-entries/article.md @@ -77,7 +77,7 @@ Các đối tượng thiếu nhiều phương thức tồn tại cho array, ví Nếu chúng ta muốn áp dụng chúng, thì chúng ta có thể sử dụng `Object.entries` theo sau là `Object.fromEntries`: 1. Sử dụng `Object.entries(obj)` để lấy một array các cặp khóa/giá trị từ `obj`. -2. Sử dụng các phương thức array trên array đó, ví dụ `map`. +2. Sử dụng các phương thức array trên array đó, ví dụ: `map`, để chuyển đổi các cặp khóa/giá trị này. 3. Sử dụng `Object.fromEntries(array)` trên array kết quả để biến nó trở lại thành một đối tượng. Ví dụ: chúng ta có một đối tượng có giá và muốn nhân đôi chúng: @@ -91,12 +91,13 @@ let prices = { *!* let doublePrices = Object.fromEntries( - // chuyển đổi thành array, map và sau đó fromEntries trả lại đối tượng - Object.entries(prices).map(([key, value]) => [key, value * 2]) + // chuyển đổi prices thành array, map từng cặp khóa/giá trị thành một cặp khác + // và sau đó fromEntries trả lại đối tượng + Object.entries(prices).map(entry => [entry[0], entry[1] * 2]) ); */!* alert(doublePrices.meat); // 8 ``` -Nó có thể trông khó khăn ngay từ cái nhìn đầu tiên, nhưng sẽ trở nên dễ hiểu sau khi bạn sử dụng nó một hoặc hai lần. Chúng ta có thể tạo ra những chuỗi biến đổi mạnh mẽ theo cách này. +Thoạt nhìn có vẻ khó, nhưng sẽ trở nên dễ hiểu sau khi bạn sử dụng một hoặc hai lần. Chúng ta có thể tạo ra những chuỗi biến đổi mạnh mẽ theo cách này.