Sự mô tảTrong JavaScript, các mảng không phải là nguyên thủy mà thay vào đó là các đối tượng ____39 với các đặc điểm cốt lõi sau: - Các mảng JavaScript có thể thay thế được và có thể chứa hỗn hợp các loại dữ liệu khác nhau. (Khi các đặc điểm đó không mong muốn, thay vào đó, hãy sử dụng các mảng được đánh máy.) and can contain a mix of different data types. (When those characteristics are undesirable, use typed arrays instead.)
- Các mảng JavaScript không phải là mảng liên kết và do đó, các phần tử mảng không thể được truy cập bằng cách sử dụng các chuỗi tùy ý làm chỉ mục, nhưng phải được truy cập bằng các số nguyên không âm (hoặc dạng chuỗi tương ứng của chúng) làm chỉ mục. and so, array elements cannot be accessed using arbitrary strings as
indexes, but must be accessed using nonnegative integers (or their respective string form) as indexes.
- Các mảng JavaScript không được chỉ số bằng không: phần tử đầu tiên của một mảng là ở Index
fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
0, phần thứ hai là tại Index fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
1, v.v.-và phần tử cuối cùng là giá trị của thuộc tính fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 của mảng trừ fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
1.: the first element of an array is at index fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
0, the second is at index fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
1, and so on — and the last element is at the value of the array's
fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 property minus fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
1. - Các hoạt động sao chép mảng JavaScript tạo các bản sao nông. (Tất cả các hoạt động sao chép tích hợp tiêu chuẩn với bất kỳ đối tượng JavaScript nào tạo các bản sao nông, thay vì các bản sao sâu).. (All standard built-in copy
operations with any JavaScript objects create shallow copies, rather than deep copies).
Chỉ số mảngfruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
9 Các đối tượng không thể sử dụng các chuỗi tùy ý làm chỉ số phần tử (như trong một mảng kết hợp) nhưng phải sử dụng các số nguyên không âm (hoặc dạng chuỗi tương ứng của chúng). Cài đặt hoặc truy cập thông qua những người không phải là thông tin sẽ không đặt hoặc truy xuất một phần tử từ chính danh sách mảng, nhưng sẽ đặt hoặc truy cập một biến được liên kết với bộ sưu tập thuộc tính đối tượng của mảng đó. Các thuộc tính đối tượng của mảng và danh sách các phần tử mảng là riêng biệt và các hoạt động di chuyển và đột biến của mảng không thể được áp dụng cho các thuộc tính được đặt tên này.Các phần tử mảng là các thuộc tính đối tượng giống như cách fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
5 là một thuộc tính (tuy nhiên, cụ thể, fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
6 là một phương thức). Tuy nhiên, cố gắng truy cập một phần tử của một mảng như sau đã ném lỗi cú pháp vì tên thuộc tính không hợp lệ:console.log(arr.0); // a syntax error
Cú pháp JavaScript yêu cầu các thuộc tính bắt đầu bằng một chữ số được truy cập bằng ký hiệu khung thay vì ký hiệu DOT. Cũng có thể trích dẫn các chỉ số mảng (ví dụ: fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
7 thay vì fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
8), mặc dù thường không cần thiết.fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
9 trong fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
8 được ép thành một chuỗi bởi công cụ JavaScript thông qua chuyển đổi fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
5 ngầm. Do đó, fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
2 và fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
3 sẽ đề cập đến hai vị trí khác nhau trên đối tượng fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
4 và ví dụ sau đây có thể là fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
5:console.log(years['2'] !== years['02']);
Chỉ fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
7 là một chỉ số mảng thực tế. fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
7 là một thuộc tính chuỗi tùy ý sẽ không được truy cập trong vòng lặp mảng.
Mối quan hệ giữa độ dài và tính chất sốThuộc tính fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 của mảng JavaScript được kết nối.Một số phương thức mảng tích hợp (ví dụ: fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
9, method(callbackFn, thisArg)
0, method(callbackFn, thisArg)
1, v.v.) có tính đến giá trị của thuộc tính fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 của mảng khi chúng được gọi.Các phương thức khác (ví dụ: method(callbackFn, thisArg)
3, method(callbackFn, thisArg)
4, v.v.) cũng dẫn đến các bản cập nhật cho thuộc tính fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 của mảng.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
Khi đặt thuộc tính trên mảng JavaScript khi thuộc tính là chỉ mục mảng hợp lệ và chỉ mục đó nằm ngoài giới hạn hiện tại của mảng, động cơ sẽ cập nhật thuộc tính fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 của mảng cho phù hợp:fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
Tăng fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2.
fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
Giảm thuộc tính fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2, tuy nhiên, xóa các yếu tố.fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
Điều này được giải thích thêm trên trang method(callbackFn, thisArg)
9.Phương pháp mảng và các khe trốngCác khe trống trong các mảng thưa thớt cư xử không nhất quán giữa các phương thức mảng. Nói chung, các phương pháp cũ hơn sẽ bỏ qua các khe trống, trong khi các phương pháp mới hơn coi chúng là const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
0.Trong số các phương pháp lặp qua nhiều yếu tố, sau đây thực hiện kiểm tra const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
1 trước khi truy cập chỉ mục và không kết hợp các khe trống với const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
0:const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
3const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
4const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
5const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
6const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
7const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
8const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
9method(callbackFn, thisArg)
1Array.prototype.flat.call({}); // []
1Array.prototype.flat.call({}); // []
2Array.prototype.flat.call({}); // []
3Array.prototype.flat.call({}); // []
4Array.prototype.flat.call({}); // []
5method(callbackFn, thisArg)
0Array.prototype.flat.call({}); // []
7Array.prototype.flat.call({}); // []
8method(callbackFn, thisArg)
4
Để biết chính xác cách họ xử lý các khe trống, hãy xem trang cho mỗi phương thức. Các phương pháp này xử lý các khe trống như thể chúng là const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
0:const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
1const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
2const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
3const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
4const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
5const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
6const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
7 Thử nghiệmExperimentalconst a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
8 Thử nghiệmExperimentalconst a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
9fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
9console.log(years['2'] !== years['02']);
01console.log(years['2'] !== years['02']);
02console.log(years['2'] !== years['02']);
03
Sao chép phương pháp và phương pháp đột biếnMột số phương thức không làm thay đổi mảng hiện tại mà phương thức đã được gọi, mà thay vào đó lại trả về một mảng mới. Họ làm như vậy bằng cách trước tiên truy cập console.log(years['2'] !== years['02']);
04 để xác định hàm tạo để sử dụng cho mảng mới. Mảng mới được xây dựng sau đó được điền với các yếu tố. Bản sao luôn xảy ra nông cạn - phương thức không bao giờ sao chép bất cứ thứ gì ngoài mảng được tạo ban đầu. Các phần tử của (các) mảng gốc được sao chép vào mảng mới như sau:- Đối tượng: Tham chiếu đối tượng được sao chép vào mảng mới. Cả mảng gốc và mảng mới đều đề cập đến cùng một đối tượng. Đó là, nếu một đối tượng được tham chiếu được sửa đổi, các thay đổi được hiển thị cho cả mảng mới và ban đầu.
- Các loại nguyên thủy như chuỗi, số và booleans (không phải
console.log(years['2'] !== years['02']);
05, console.log(years['2'] !== years['02']);
06 và console.log(years['2'] !== years['02']);
07 đối tượng): giá trị của chúng được sao chép vào mảng mới.
Các phương thức khác làm biến đổi mảng mà phương thức được gọi, trong trường hợp giá trị trả về của chúng khác nhau tùy thuộc vào phương thức: đôi khi một tham chiếu đến cùng một mảng, đôi khi độ dài của mảng mới. Các phương thức sau tạo các mảng mới với console.log(years['2'] !== years['02']);
08:const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
3const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
6const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
7const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
8Array.prototype.flat.call({}); // []
2method(callbackFn, thisArg)
0method(callbackFn, thisArg)
4 (để xây dựng mảng các phần tử bị loại bỏ đã được trả về)
Lưu ý rằng const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
7 và const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
8 không sử dụng console.log(years['2'] !== years['02']);
08 để tạo các mảng mới cho mỗi mục nhập nhóm, nhưng luôn sử dụng hàm tạo fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
9 trơn. Về mặt khái niệm, họ cũng không sao chép các phương pháp.Các phương pháp sau đây làm biến đổi mảng ban đầu: const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
4const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
2console.log(years['2'] !== years['02']);
22method(callbackFn, thisArg)
3Array.prototype.flat.call({}); // []
5console.log(years['2'] !== years['02']);
25Array.prototype.flat.call({}); // []
8method(callbackFn, thisArg)
4console.log(years['2'] !== years['02']);
28
Phương pháp lặpNhiều phương thức mảng lấy chức năng gọi lại làm đối số. Hàm gọi lại được gọi là tuần tự và nhiều nhất một lần cho mỗi phần tử trong mảng và giá trị trả về của hàm gọi lại được sử dụng để xác định giá trị trả về của phương thức. Tất cả họ đều có chung chữ ký: method(callbackFn, thisArg)
Trong đó console.log(years['2'] !== years['02']);
29 lấy ba đối số:console.log(years['2'] !== years['02']);
30Phần tử hiện tại được xử lý trong mảng. console.log(years['2'] !== years['02']);
31Chỉ số của phần tử hiện tại được xử lý trong mảng. console.log(years['2'] !== years['02']);
32Mảng const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
8 đã được yêu cầu.Những gì console.log(years['2'] !== years['02']);
29 dự kiến sẽ trở lại phụ thuộc vào phương thức mảng được gọi.Đối số console.log(years['2'] !== years['02']);
35 (mặc định là const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
0) sẽ được sử dụng làm giá trị console.log(years['2'] !== years['02']);
37 khi gọi console.log(years['2'] !== years['02']);
29. Giá trị console.log(years['2'] !== years['02']);
37 có thể quan sát cuối cùng bởi console.log(years['2'] !== years['02']);
29 được xác định theo các quy tắc thông thường: nếu console.log(years['2'] !== years['02']);
29 không nghiêm ngặt, các giá trị console.log(years['2'] !== years['02']);
37 nguyên thủy được bọc thành các đối tượng và ________ 70/________ 144 được thay thế bằng console.log(years['2'] !== years['02']);
45. Đối số console.log(years['2'] !== years['02']);
35 không liên quan đến bất kỳ console.log(years['2'] !== years['02']);
29 nào được xác định với hàm mũi tên, vì các hàm mũi tên không có ràng buộc console.log(years['2'] !== years['02']);
37 riêng của chúng.Tất cả các phương pháp lặp là sao chép và chung chung, mặc dù chúng hoạt động khác nhau với các khe trống. Các phương pháp sau là lặp đi lặp lại: const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
5const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
6const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
3const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
4const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
5const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
6const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
8const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
9const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
7const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
8Array.prototype.flat.call({}); // []
2Array.prototype.flat.call({}); // []
7
Cụ thể, const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
5, const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
3, const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
4, const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
5, const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
6 và Array.prototype.flat.call({}); // []
7 không phải lúc nào cũng gọi console.log(years['2'] !== years['02']);
29 trên mọi yếu tố - chúng dừng lặp lại ngay khi giá trị trả về được xác định.Có hai phương pháp khác có chức năng gọi lại và chạy nó nhiều nhất một lần cho mỗi phần tử trong mảng, nhưng chúng có chữ ký hơi khác nhau từ các phương thức lặp điển hình (ví dụ: chúng không chấp nhận console.log(years['2'] !== years['02']);
35):Phương thức Array.prototype.flat.call({}); // []
8 cũng có hàm gọi lại, nhưng nó không phải là phương thức lặp. Nó làm đột biến mảng tại chỗ, không chấp nhận console.log(years['2'] !== years['02']);
35 và có thể gọi cuộc gọi lại nhiều lần trên một chỉ mục.Phương pháp mảng chungCác phương thức mảng luôn chung chung - chúng không truy cập bất kỳ dữ liệu nội bộ nào của đối tượng mảng. Họ chỉ truy cập các phần tử mảng thông qua thuộc tính fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 và các phần tử được lập chỉ mục. Điều này có nghĩa là chúng cũng có thể được gọi trên các đối tượng giống như mảng.
const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
Bình thường hóa thuộc tính chiều dàiThuộc tính fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 được chuyển đổi thành một số nguyên và sau đó được kẹp đến phạm vi từ 0 đến 253 - 1. console.log(years['2'] !== years['02']);
75 trở thành fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
0, vì vậy ngay cả khi fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 không có hoặc là const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
0, nó hoạt động như thể nó có giá trị fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
0.Array.prototype.flat.call({}); // []
Một số phương thức mảng đặt thuộc tính fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 của đối tượng mảng. Họ luôn đặt giá trị sau khi chuẩn hóa, do đó fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 luôn kết thúc như một số nguyên.const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
Các đối tượng giống như mảngThuật ngữ đối tượng giống như mảng đề cập đến bất kỳ đối tượng nào không ném trong quá trình chuyển đổi fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 được mô tả ở trên. Trong thực tế, đối tượng như vậy dự kiến sẽ thực sự có thuộc tính fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 và có các phần tử được lập chỉ mục trong phạm vi fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
0 đến console.log(years['2'] !== years['02']);
85. (Nếu nó không có tất cả các chỉ số, nó sẽ tương đương về mặt chức năng với một mảng thưa thớt.)Nhiều đối tượng DOM giống như mảng-ví dụ, console.log(years['2'] !== years['02']);
86 và console.log(years['2'] !== years['02']);
87. Đối tượng console.log(years['2'] !== years['02']);
88 cũng giống như mảng. Bạn có thể gọi các phương thức mảng trên chúng ngay cả khi chúng không có các phương thức này.console.log(years['2'] !== years['02']);
0Người xây dựngconsole.log(years['2'] !== years['02']);
89Tạo một đối tượng fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
9 mới.Tính chất tĩnhconsole.log(years['2'] !== years['02']);
91Trả về hàm tạo fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
9.Phương pháp tĩnhconsole.log(years['2'] !== years['02']);
93Tạo một thể hiện fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
9 mới từ một đối tượng giống như mảng hoặc đối tượng có thể lặp lại.console.log(years['2'] !== years['02']);
95Trả về fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
5 nếu đối số là một mảng hoặc console.log(years['2'] !== years['02']);
97 khác.console.log(years['2'] !== years['02']);
98Tạo một thể hiện fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
9 mới với một số lượng đối số thay đổi, bất kể số hoặc loại đối số.
Thuộc tính thể hiệnconst fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
00Phản ánh số lượng các yếu tố trong một mảng. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
01Chứa các tên thuộc tính không được bao gồm trong tiêu chuẩn ECMAScript trước phiên bản ES2015 và bị bỏ qua cho các mục đích liên kết tuyên bố const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
02.
Phương pháp thể hiệnconst fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
03Trả về mục mảng tại chỉ mục đã cho. Chấp nhận số nguyên âm, được tính lại từ mục cuối cùng. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
04Trả về một mảng mới là mảng gọi được nối với (các) mảng khác và/hoặc giá trị. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
05Sao chép một chuỗi các phần tử mảng trong một mảng. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
06Trả về một đối tượng lặp mảng mới chứa các cặp khóa/giá trị cho mỗi chỉ mục trong một mảng. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
07Trả về fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
5 Nếu mọi phần tử trong mảng gọi thỏa mãn chức năng kiểm tra.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
09Điền vào tất cả các phần tử của một mảng từ chỉ mục bắt đầu sang chỉ mục cuối với giá trị tĩnh. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
10Trả về một mảng mới chứa tất cả các phần tử của mảng gọi mà hàm lọc được cung cấp trả về fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
5.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
12Trả về giá trị của phần tử đầu tiên trong mảng thỏa mãn chức năng thử nghiệm được cung cấp hoặc const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
0 nếu không tìm thấy phần tử thích hợp.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
14Trả về chỉ số của phần tử đầu tiên trong mảng thỏa mãn chức năng thử nghiệm được cung cấp hoặc const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
15 nếu không tìm thấy phần tử thích hợp.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
16Trả về giá trị của phần tử cuối cùng trong mảng thỏa mãn chức năng thử nghiệm được cung cấp hoặc const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
0 nếu không tìm thấy phần tử thích hợp.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
18Trả về chỉ số của phần tử cuối cùng trong mảng thỏa mãn chức năng thử nghiệm được cung cấp hoặc const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
15 nếu không tìm thấy phần tử thích hợp.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
20Trả về một mảng mới với tất cả các yếu tố mảng con được liên kết vào nó đệ quy lên đến độ sâu được chỉ định. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
21Trả về một mảng mới được hình thành bằng cách áp dụng một hàm gọi lại đã cho cho từng phần tử của mảng gọi, sau đó làm phẳng kết quả theo một cấp. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
22Gọi một hàm cho mỗi phần tử trong mảng gọi. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
23 Thử nghiệmExperimentalNhóm các phần tử của một mảng thành một đối tượng theo các chuỗi được trả về bởi một hàm thử nghiệm. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
24 Thử nghiệmExperimentalNhóm các phần tử của một mảng thành const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
25 theo các giá trị được trả về bởi hàm thử nghiệm.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
26Xác định xem mảng gọi có chứa giá trị hay không, trả về fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
5 hay console.log(years['2'] !== years['02']);
97 nếu thích hợp.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
29Trả về chỉ mục đầu tiên (ít nhất) mà tại đó một phần tử nhất định có thể được tìm thấy trong mảng gọi. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
30Tham gia tất cả các yếu tố của một mảng thành một chuỗi. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
31Trả về một trình lặp mảng mới chứa các phím cho mỗi chỉ mục trong mảng gọi. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
32Trả về chỉ mục cuối cùng (lớn nhất) mà tại đó một phần tử nhất định có thể được tìm thấy trong mảng gọi hoặc const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
15 nếu không tìm thấy.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
34Trả về một mảng mới chứa kết quả gọi một hàm trên mọi phần tử trong mảng gọi. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
35Loại bỏ phần tử cuối cùng khỏi một mảng và trả về phần tử đó. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
36Thêm một hoặc nhiều phần tử vào cuối một mảng và trả về fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 mới của mảng.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
38Thực thi chức năng gọi lại "giảm" do người dùng cung cấp trên mỗi phần tử của mảng (từ trái sang phải), để giảm nó xuống một giá trị duy nhất. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
39Thực thi chức năng gọi lại "giảm" do người dùng cung cấp trên mỗi phần tử của mảng (từ phải sang trái), để giảm nó xuống một giá trị duy nhất. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
40Đảo ngược thứ tự của các yếu tố của một mảng tại chỗ. (Đầu tiên trở thành người cuối cùng, lần cuối cùng trở thành đầu tiên.) const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
41Loại bỏ phần tử đầu tiên khỏi một mảng và trả về phần tử đó. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
42Trích xuất một phần của mảng gọi và trả về một mảng mới. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
43Trả về fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
5 Nếu ít nhất một phần tử trong mảng gọi thỏa mãn chức năng kiểm tra được cung cấp.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
45Sắp xếp các phần tử của một mảng tại chỗ và trả về mảng. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
46Thêm và/hoặc loại bỏ các yếu tố khỏi một mảng. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
47Trả về một chuỗi cục bộ đại diện cho mảng gọi và các yếu tố của nó. Ghi đè phương thức const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
48.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
49Trả về một chuỗi đại diện cho mảng gọi và các phần tử của nó. Ghi đè phương thức const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
50.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
51Thêm một hoặc nhiều phần tử vào mặt trước của một mảng và trả về fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
2 mới của mảng.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
53Trả về một đối tượng lặp mảng mới chứa các giá trị cho mỗi chỉ mục trong mảng. const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
54Một bí danh cho phương thức console.log(years['2'] !== years['02']);
03 theo mặc định.Ví dụPhần này cung cấp một số ví dụ về các hoạt động mảng phổ biến trong JavaScript. Tạo một mảngVí dụ này hiển thị ba cách để tạo mảng mới: đầu tiên sử dụng ký hiệu theo nghĩa đen của mảng, sau đó sử dụng hàm tạo console.log(years['2'] !== years['02']);
89 và cuối cùng sử dụng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
57 để xây dựng mảng từ một chuỗi.console.log(years['2'] !== years['02']);
1Tạo một chuỗi từ một mảngVí dụ này sử dụng phương thức fruits.length = 2;
console.log(Object.keys(fruits)); // ['0', '1']
console.log(fruits.length); // 2
9 để tạo một chuỗi từ mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59.console.log(years['2'] !== years['02']);
2Truy cập một mục mảng theo chỉ mục của nóVí dụ này cho thấy cách truy cập các mục trong mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59 bằng cách chỉ định số chỉ mục của vị trí của chúng trong mảng.console.log(years['2'] !== years['02']);
3Tìm chỉ mục của một mục trong một mảngVí dụ này sử dụng phương thức method(callbackFn, thisArg)
1 để tìm vị trí (chỉ mục) của chuỗi const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
62 trong mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59.console.log(years['2'] !== years['02']);
4Kiểm tra xem một mảng có chứa một mục nào đó khôngVí dụ này cho thấy hai cách để kiểm tra xem mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59 có chứa const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
62 và const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
66: Đầu tiên với phương thức const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
9, sau đó với phương thức method(callbackFn, thisArg)
1 để kiểm tra giá trị chỉ mục không phải là const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
15.console.log(years['2'] !== years['02']);
5Nối một mục vào một mảngVí dụ này sử dụng phương thức method(callbackFn, thisArg)
3 để nối một chuỗi mới vào mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59.console.log(years['2'] !== years['02']);
6Xóa mục cuối cùng khỏi một mảngVí dụ này sử dụng phương thức console.log(years['2'] !== years['02']);
22 để xóa mục cuối cùng khỏi mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59.console.log(years['2'] !== years['02']);
7Lưu ý: console.log(years['2'] !== years['02']);
22 chỉ có thể được sử dụng để loại bỏ mục cuối cùng khỏi một mảng. Để loại bỏ nhiều mục từ cuối một mảng, hãy xem ví dụ tiếp theo.
console.log(years['2'] !== years['02']);
22 can only be used to remove the last item from an array. To remove multiple items from the end of an array, see the next example.Xóa nhiều mục từ cuối một mảngVí dụ này sử dụng phương thức method(callbackFn, thisArg)
4 để loại bỏ 3 mục cuối cùng khỏi mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59.console.log(years['2'] !== years['02']);
8Cắt ngắn một mảng xuống chỉ là n mục đầu tiên của nóVí dụ này sử dụng phương thức method(callbackFn, thisArg)
4 để cắt giảm mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59 xuống chỉ còn 2 mục đầu tiên.console.log(years['2'] !== years['02']);
9Xóa mục đầu tiên khỏi một mảngVí dụ này sử dụng phương thức console.log(years['2'] !== years['02']);
25 để xóa mục đầu tiên khỏi mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
0Lưu ý: console.log(years['2'] !== years['02']);
25 chỉ có thể được sử dụng để loại bỏ mục đầu tiên khỏi một mảng. Để loại bỏ nhiều mục từ đầu một mảng, hãy xem ví dụ tiếp theo. console.log(years['2'] !== years['02']);
25 can only be used to remove the first item from an array. To remove multiple items from the beginning of an array, see the next example.Xóa nhiều mục từ đầu một mảngVí dụ này sử dụng phương thức method(callbackFn, thisArg)
4 để loại bỏ 3 mục đầu tiên khỏi mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
1Thêm một mục đầu tiên mới vào một mảngVí dụ này sử dụng phương thức console.log(years['2'] !== years['02']);
28 để thêm, tại Index fruits.length = 10;
console.log(fruits); // ['banana', 'apple', 'peach', empty x 2, 'mango', empty x 4]
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 10
console.log(fruits[8]); // undefined
0, một mục mới cho mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59 - biến nó thành mục đầu tiên mới trong mảng.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
2Xóa một mục duy nhất bằng chỉ mụcVí dụ này sử dụng phương thức method(callbackFn, thisArg)
4 để xóa chuỗi const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
62 khỏi mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59 - bằng cách chỉ định vị trí chỉ mục của const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
62.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
3Xóa nhiều mục bằng chỉ mụcVí dụ này sử dụng phương thức method(callbackFn, thisArg)
4 để loại bỏ các chuỗi const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
62 và const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
93 khỏi mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59 - bằng cách chỉ định vị trí chỉ mục của const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
62, cùng với số lượng tổng số mục để xóa.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
4Thay thế nhiều mục trong một mảngVí dụ này sử dụng phương thức method(callbackFn, thisArg)
4 để thay thế 2 mục cuối cùng trong mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59 bằng các mục mới.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
5Lặp lại trên một mảngVí dụ này sử dụng vòng lặp const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
98 để lặp qua mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59, đăng nhập từng mục vào bảng điều khiển.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
6Nhưng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
98 chỉ là một trong nhiều cách để lặp lại bất kỳ mảng nào; Để biết thêm các cách, hãy xem các vòng lặp và lặp, và xem tài liệu cho const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
5, const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
6, const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
8, Array.prototype.flat.call({}); // []
2, Array.prototype.flat.call({}); // []
3 và Array.prototype.flat.call({}); // []
4 - và xem ví dụ tiếp theo, sử dụng phương thức const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
9.Gọi một hàm trên mỗi phần tử trong một mảng
Ví dụ này sử dụng phương thức const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
9 để gọi hàm trên mỗi phần tử trong mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59; Hàm làm cho mỗi mục được ghi vào bảng điều khiển, cùng với số chỉ mục của mục.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
7Hợp nhất nhiều mảng với nhauVí dụ này sử dụng phương thức const arrayLike = {
0: "a",
1: "b",
length: 2,
};
console.log(Array.prototype.join.call(arrayLike, "+")); // 'a+b'
3 để hợp nhất mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59 với mảng fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
12, để tạo ra một mảng fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
13 mới. Lưu ý rằng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59 và fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
12 vẫn không thay đổi.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
8Sao chép một mảngVí dụ này cho thấy ba cách để tạo một mảng mới từ mảng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
59 hiện có: đầu tiên bằng cách sử dụng cú pháp lan truyền, sau đó bằng cách sử dụng phương thức fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
17, sau đó bằng cách sử dụng phương thức method(callbackFn, thisArg)
0.const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
9Tất cả các hoạt động sao chép mảng tích hợp (cú pháp lan truyền, console.log(years['2'] !== years['02']);
93, const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
42 và const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
04) tạo ra các bản sao nông. Thay vào đó, nếu bạn muốn có một bản sao sâu của một mảng, bạn có thể sử dụng fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
22 để chuyển đổi mảng thành chuỗi JSON và sau đó fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
23 để chuyển đổi chuỗi trở lại thành một mảng mới hoàn toàn độc lập với mảng gốc.fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
0Bạn cũng có thể tạo các bản sao sâu bằng phương pháp fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
24, có lợi thế cho phép các đối tượng có thể chuyển được trong nguồn được chuyển sang bản sao mới, thay vì chỉ nhân bản.Cuối cùng, điều quan trọng là phải hiểu rằng việc gán một mảng hiện có cho một biến mới không tạo ra một bản sao của mảng hoặc các phần tử của nó. Thay vào đó, biến mới chỉ là một tham chiếu, hoặc bí danh, cho mảng gốc; Đó là, tên của mảng gốc và tên biến mới chỉ là hai tên cho cùng một đối tượng (và do đó sẽ luôn đánh giá là tương đương nghiêm ngặt). Do đó, nếu bạn thực hiện bất kỳ thay đổi nào theo giá trị của mảng gốc hoặc với giá trị của biến mới, thì cũng sẽ thay đổi: fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
1Nhóm các yếu tố của một mảngCác phương thức const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
23 có thể được sử dụng để nhóm các phần tử của mảng, sử dụng hàm thử nghiệm trả về một chuỗi biểu thị nhóm của phần tử hiện tại.Ở đây chúng tôi có một mảng hàng tồn kho đơn giản có chứa các đối tượng "thực phẩm" có fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
26 và fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
27.fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
2Để sử dụng const a = { length: 0.7 };
Array.prototype.push.call(a);
console.log(a.length); // 0
7, bạn cung cấp chức năng gọi lại được gọi với phần tử hiện tại và tùy chọn chỉ mục và mảng hiện tại và trả về một chuỗi chỉ ra nhóm của phần tử. Mã bên dưới sử dụng hàm mũi tên để trả về fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
27 của mỗi phần tử mảng (điều này sử dụng cú pháp phá hủy đối tượng cho các đối số chức năng để giải nén phần tử fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
27 khỏi đối tượng được truyền). Kết quả là một đối tượng có các thuộc tính được đặt tên theo các chuỗi duy nhất được trả về bởi cuộc gọi lại. Mỗi thuộc tính được gán một mảng chứa các phần tử trong nhóm.fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
3
Lưu ý rằng đối tượng được trả về tham chiếu các phần tử giống như mảng gốc (không phải bản sao sâu). Thay đổi cấu trúc bên trong của các yếu tố này sẽ được phản ánh trong cả mảng gốc và đối tượng được trả về. Ví dụ, nếu bạn không thể sử dụng chuỗi làm khóa làm khóa, nếu thông tin đến nhóm được liên kết với một đối tượng có thể thay đổi, thì thay vào đó bạn có thể sử dụng const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
24. Điều này rất giống với fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
32 ngoại trừ việc nó nhóm các phần tử của mảng thành const fruits = [];
fruits.push('banana', 'apple', 'peach');
console.log(fruits.length); // 3
25 có thể sử dụng giá trị tùy ý (đối tượng hoặc nguyên thủy) làm chìa khóa.Tạo một mảng hai chiềuSau đây tạo ra một bàn cờ như một chuỗi hai chiều. Động thái đầu tiên được thực hiện bằng cách sao chép fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
34 trong fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
35 lên fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
36. Vị trí cũ tại fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
37 được làm trống.fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
4Đây là đầu ra: fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
5Sử dụng một mảng để lập bảng một tập hợp các giá trịfruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
6Kết quả trong fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
7Tạo một mảng bằng kết quả của một trận đấuKết quả của một trận đấu giữa fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
38 và một chuỗi có thể tạo ra một mảng JavaScript có thuộc tính và phần tử cung cấp thông tin về trận đấu. Một mảng như vậy được trả về bởi fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
39 và fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
40.Ví dụ: fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
8Để biết thêm thông tin về kết quả của một trận đấu, hãy xem trang fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
39 và fruits[5] = 'mango';
console.log(fruits[5]); // 'mango'
console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
console.log(fruits.length); // 6
40.Thông số kỹ thuật
Sự chỉ rõ |
---|
Đặc tả ngôn ngữ Ecmascript # sec-marray-expects # sec-array-objects
|
Tính tương thích của trình duyệt webBảng BCD chỉ tải trong trình duyệt
Làm thế nào mảng được sử dụng trong JavaScript giải thích?
Trong JavaScript, mảng là một biến duy nhất được sử dụng để lưu trữ các yếu tố khác nhau.Nó thường được sử dụng khi chúng tôi muốn lưu trữ một danh sách các yếu tố và truy cập chúng bằng một biến duy nhất.to store different elements. It is often used when we want to store a list of elements and access them by a single variable.
Làm thế nào để một mảng hoạt động?
Một mảng là một đối tượng container chứa một số giá trị cố định của một loại.Độ dài của một mảng được thiết lập khi mảng được tạo.Sau khi tạo, chiều dài của nó được cố định.Bạn đã thấy một ví dụ về các mảng, trong phương pháp chính của "Hello World!"đăng kí.. The length of an array is established when the array is created. After creation, its length is fixed. You have seen an example of arrays already, in the main method of the "Hello World!" application.
{} Và [] trong javascript là gì?
{} là tốc ký để tạo một đối tượng trống.Bạn có thể coi đây là cơ sở cho các loại đối tượng khác.Đối tượng cung cấp liên kết cuối cùng trong chuỗi nguyên mẫu có thể được sử dụng bởi tất cả các đối tượng khác, chẳng hạn như một mảng.[] là tốc ký để tạo ra một mảng trống.. You can consider this as the base for other object types. Object provides the last link in the prototype chain that can be used by all other objects, such as an Array . [] is shorthand for creating an empty array. |