4 min read

Spread Operator và Rest Operator trong Javasccript

Giải thích chi tiết về cách sử dụng Spread Operator (...) để tách chuỗi, nối mảng và Rest Operator để xử lý tham số trong JavaScript với các ví dụ thực tế và trực quan.

Spread Operator và Rest Operator trong Javasccript

Spread Operator và Rest Operator trong Javasccript

Spread Operator là gì?

Chắc hẳn, không ít lần bạn thấy ba dấu chấm ... trong Javascript thế này, và tự hỏi cài quỷ này là gì, hôm nay chúng ta sẽ cùng tìm hiểu 3 dấu chấm đó nhé.

Spread tức là 'banh ra', tức là thấy gì sẽ banh nó ra, thôi thì ta cứ đi vào ví dụ cụ thể để bạn dễ hiểu hơn nhé

Spread chuỗi

Ta thử gõ như sau vào Consoletrong trình duyệt để xài Command Line API

Thì sẽ được kết quả sau:

Tức là spread operator đang 'tách' chuỗi string là thành mảng phần tử

Nối mảng

Ví dụ có mảng sau:

const iphones = ['iphone4','iphone5','iphone6'];
const macbooks = ['macbook2012','macbook2013','macbook2014'];

Ta muốn gộp 2 mảng này thành một mảng thì làm như sau:

const AppleProducts = iphones.concat(macbooks);

// ["iphone4", "iphone5", "iphone6", "macbook2012", "macbook2013", "macbook2014"]

Nhưng ta muốn thêm iphone7 , iphone7s và sau mảng iphonesmacbook2011 trước macbooks , macbook2015 vào sau cùng thì phải concat rồi push phần tử vô nhiều lần đúng không?

Nhưng với spread operator, mọi chuyện đã nhanh gọn lẹn hơn như sau:

const AppleProducts = [ ...iphones, "iphone7", "iphone7s", "macbook2011", ...macbooks, "macbook2015" ];

//["iphone4", "iphone5", "iphone6", "iphone7", "iphone7s", "macbook2011", "macbook2012", "macbook2013", "macbook2014", "macbook2015"]

Copy Array

Nếu ta copy như thế này thì không đúng:

const oldModels = macbooks;
oldModels[0] = "macbook2010";

// macbooks: ["macbook2010", "macbook2013", "macbook2014"]

Vì khi gán bằng thì khi oldModels thay đổi thì macbooks cũng thay đổi theo.

Với spread operator, ta có thể copy mảng an toàn hơn như sau:

const oldModels = [...macbooks];
oldModels[0] = "macbook2010";

// macbooks: ["macbook2012", "macbook2013", "macbook2014"]

Spread operator khi gọi hàm

Ví dụ ta có hàm tính tổng sum, trong hàm này dùng for ... of

const values = [69,96,1];

function sum(){ 
  var total = 0;
  for (const value of arguments){
    total += value;
  } 
  return total;
} 

console.log(sum(values[0],values[1],values[2]));
// 166

Mà lỡ cái mảng ta truyển vào có 100 phần tử, chẳng lẽ cùng truyền 100 đối số vào sao? Mọi việc sẽ đơn giản hơn nếu dùng spread operator:

console.log(sum(...values)) // 166

...Rest Operator là gì?

Cũng là ba dấu chấm ... nhưng rest lại có cách dùng khác hoàn toàn với spread. Spread tức là banh ra, tách ra, từ một array thành nhiều phần tử.

Còn rest thì ngược lại: gom những phần tử thành array. Rest operator được dùng trong parameter của function và destructuring

...rest trong function

Ví dụ ta có hàm tính điểm trung bình học sinh, với toán, văn nhân hệ số 2, còn lại bao nhiêu môn không cần biết hệ số 1. Mình sẽ viết theo kiểu dùng ...rest luôn, bạn có thể viết lại dùng arguments của hàm và sẽ nhận thấy rằng dùng ...rest sẽ tiết kiệm vài dòng code và nhìn pro hẳn lên

function calculateGPA(math, literature, ...otherSubject){ 
  console.log(otherSubject); // [6, 7, 5, 4] 
}

calculateGPA(8, 7.5, 6, 7, 5, 4);

Lúc này bạn sẽ thấy otherSubject là một array, tức là ...rest đã gom lại thành 1 mảng rồi. Công việc bây giờ chỉ cần dùng hàm sum() ở trên là xong:

function calculateGPA(math, literature, ...otherSubject){
    return (math * 2 + literature * 2 + sum(...otherSubject)) / (otherSubject.length + 4);
}

console.log(calculateGPA(8, 7.5, 6, 7, 5, 4));
// 6.625

Tiếp theo còn một trường hợp hay dùng Rest nữa đó là:

...rest với Destructuring

const VietNamTeam = [ "Nguyen Huu Thang", "Nguyen Cong Phuong", "Luong Xuan Truong", "Nguyen Van Toan", "Nguyen Tuan Anh", "Phan Van Hau", "Ha Duc Chinh" ];

const [coach, captain, ...players] = VietNamTeam;

console.log(coach);
console.log(captain);
console.log(players);

// Nguyen Huu Thang
// Nguyen Cong Phuong
// ["Luong Xuan Truong", "Nguyen Van Toan", "Nguyen Tuan Anh", "Phan Van Hau", "Ha Duc Chinh"]

Kết

Hy vọng với bài viết này, bạn đã hiểu rõ cũng như phân biệt được Spread Operator và Rest Operator. Mọi góp ý và thắc mắc hãy comment chia sẻ nhé!

Related Posts

Discover more content you might enjoy