JavaScript
  • JavaScript Introduction
  • JS Engine
  • V8 Engine
  • First-class function
  • Optimized Code
  • Call Stack & Memory heap
  • Single Thread
  • JavaScript RunTime
  • Nodejs
  • Context and Environment
  • Hoisting
  • Functions
  • Arguments
  • Variables
  • Scope
  • IIFE
  • this
  • call(), apply() and bind()
  • currying
  • Types
  • Type Coercion
  • Functions as Object
  • HOF (Higher Order Function)
  • Two pillars of Javascript
  • Closures
  • Prototypal Inheritance
  • OOP and FP
  • OOP
    • 4 principles of OOP
  • FP
    • Pure function
    • Imperative vs Declarative
    • Immutability
    • HOF and Closures
    • Currying
    • Partial Application
    • Compose and Pipe
  • Composition vs Inheritance
  • OOP vs FP
  • JS working
  • Promises
  • Async Await
  • ES5 - ECMAScript 2009
  • ES6 - ECMAScript 2015
  • ES7 - ECMAScript 2016
  • ES8 - ECMAScript 2017
  • ES9 - ECMAScript 2018
  • ES10 - ECMAScript 2019
  • ES11 - ECMAScript 2020
  • ES12 - ECMAScript 2021
  • JOB Queue
  • Promises Execution
Powered by GitBook
On this page

Was this helpful?

  1. FP

Immutability

Immutability means not changing the data, not changing the state.

In functional programming, the idea of immutability is not changing the state, instead taking copies of the state and returning a new state every time.

Ex:
const obj = { name: 'Vijay' };
function clone(obj) {
    return { ...obj }; // this is pure
}
// obj.name = 'Nana'; // mutating the data
// insted mutating create function to update name
function updateName(obj) {
    const newObj = clone(obj);
    newObj.name = 'Nana';
    return newObj;
}

const updatedbj = updateName(obj);
console.log(obj, updatedbj); // { name: 'Vijay' } { name: 'Nana' } // immutability
PreviousImperative vs DeclarativeNextHOF and Closures

Last updated 5 years ago

Was this helpful?