Modern JavaScript (ES6+) for Beginners
Lesson 6 of 12 50% of course

Spread & Rest Operators (...)

1 · 5 min · 6/7/2026

Learn Spread & Rest Operators (...) in our free Modern JavaScript (ES6+) for Beginners series. Step-by-step explanations, examples, and interview tips on Toolliyo Academy.

Sign in to track progress and bookmarks.

Spread & Rest Operators (...)
Lesson 6 of 12 · Part 2 — Write Less Code · Modern JavaScript (ES6+) for Beginners
Course: Modern JavaScript (ES6+) for Beginners · Lesson: 6/12 · Read time: ~16 min · Level: Beginner · ES version: ES2015 (ES6) and above

Spread & Rest Operators (...)

The three dots ... do two related jobs: spread expands arrays/objects; rest collects remaining items. Both are everywhere in React (copy state) and Node (merge config).

Spread — copy & merge

const defaults = { theme: 'dark', lang: 'en' };
const userPrefs = { lang: 'hi', fontSize: 16 };

const settings = { ...defaults, ...userPrefs };
// { theme: 'dark', lang: 'hi', fontSize: 16 }

const arr1 = [1, 2];
const arr2 = [...arr1, 3, 4];  // [1, 2, 3, 4]

Rest — collect remaining

function sum(first, ...rest) {
  return rest.reduce((total, n) => total + n, first);
}
sum(10, 5, 3, 2);  // 20

const [leader, ...team] = ['Sandeep', 'Alex', 'Priya'];
// leader = 'Sandeep', team = ['Alex', 'Priya']
🌍 Real-world example — React-style state update (concept)
const cart = [{ id: 1, qty: 1 }];

function addToCart(cart, newItem) {
  return [...cart, newItem];  // new array — do not mutate old
}

addToCart(cart, { id: 2, qty: 1 });
// cart unchanged; new array returned

React uses this idea: spread creates a new array/object so the UI knows something changed.

⚠️ Common Mistake: Mutating state directly: cart.push(item) then expecting React to re-render. Use spread to return a new array.
💡 Tip: Order matters when merging objects: later spreads overwrite earlier keys.
👨‍🏫 Teaching note: Show shallow copy vs reference: change nested object after spread — nested object is still shared. Deep clone needs other tools.

Continue learning

Previous: Destructuring — Arrays & Objects

Next: Default Parameters & Object Shorthand

Course home: All 12 lessons

Test your knowledge

Quizzes linked to this course—pass to earn certificates.

Browse all quizzes
Modern JavaScript (ES6+) for Beginners

On this page

Spread — copy & merge Rest — collect remaining Continue learning
Part 1 — Modern Basics
Introduction — Why ES6+ Before Node.js & React let, const & Block Scope Arrow Functions Explained
Part 2 — Write Less Code
Template Literals & Modern Strings Destructuring — Arrays & Objects Spread & Rest Operators (...)
Part 3 — Data & Collections
Default Parameters & Object Shorthand Array Methods — map, filter, find & reduce for...of, Sets & Maps Essentials
Part 4 — Async & Modules
Promises — then, catch & finally async/await & Fetch API Modules — import/export & What to Learn Next
Toolliyo Assistant
Ask about tutorials, ebooks, training, pricing, mentor services, and support. I use public site content only—not admin or internal tools.

care@toolliyo.com

Need callback? Share your details