Observables vs Promises

Asynchronous programming is a cornerstone of modern web development, enabling applications to handle tasks such as data fetching, event handling, and real-time updates without blocking the main execution thread. Two powerful tools for managing asynchro…


This content originally appeared on DEV Community and was authored by Shaikh AJ

Asynchronous programming is a cornerstone of modern web development, enabling applications to handle tasks such as data fetching, event handling, and real-time updates without blocking the main execution thread. Two powerful tools for managing asynchronous operations in JavaScript are Observables and Promises. This article delves into the differences between Observables and Promises, providing clear examples to help you understand when and how to use each.

Table of Contents

  1. Introduction to Promises
  2. Introduction to Observables
  3. Key Differences Between Promises and Observables
  4. Examples
    • Example 1: Simple Asynchronous Operation
    • Example 2: Handling Multiple Values Over Time
    • Example 3: Cancellation
  5. When to Use Promises vs. Observables
  6. Conclusion

Introduction to Promises

Promises are a modern JavaScript feature designed to handle asynchronous operations. A Promise represents a single value that will be available now, in the future, or never. It can be in one of three states: pending, fulfilled, or rejected.

Creating a Promise

const myPromise = new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve('Promise resolved!');
  }, 1000);
});

Consuming a Promise

myPromise.then(value => {
  console.log(value);
}).catch(error => {
  console.error(error);
});

Output

Promise resolved!

Introduction to Observables

Observables are a key feature of the Reactive Extensions (RxJS) library, used extensively in frameworks like Angular. An Observable is a stream of data that can emit multiple values over time. Unlike Promises, Observables are lazy and can be canceled.

Creating an Observable

import { Observable } from 'rxjs';

const myObservable = new Observable(observer => {
  setTimeout(() => {
    observer.next('First value');
  }, 1000);

  setTimeout(() => {
    observer.next('Second value');
  }, 2000);

  setTimeout(() => {
    observer.complete();
  }, 3000);
});

Subscribing to an Observable

myObservable.subscribe({
  next(value) {
    console.log(value);
  },
  error(err) {
    console.error('Error:', err);
  },
  complete() {
    console.log('Completed');
  }
});

Output

First value
Second value
Completed

Key Differences Between Promises and Observables

  • Single vs. Multiple Values: Promises resolve to a single value, while Observables can emit multiple values over time.
  • Eager vs. Lazy: Promises are eager, meaning they start executing immediately, whereas Observables are lazy and do not start until they are subscribed to.
  • Cancellation: Promises cannot be canceled once initiated. Observables can be canceled by unsubscribing.
  • Operators: Observables come with a rich set of operators (e.g., map, filter, debounce) for transforming and composing data streams.

Examples

Example 1: Simple Asynchronous Operation

Using Promises

const fetchDataPromise = () => {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      resolve('Data fetched using Promise');
    }, 1000);
  });
};

fetchDataPromise().then(data => {
  console.log(data);
});

Output

Data fetched using Promise

Using Observables

import { Observable } from 'rxjs';

const fetchDataObservable = new Observable(observer => {
  setTimeout(() => {
    observer.next('Data fetched using Observable');
    observer.complete();
  }, 1000);
});

fetchDataObservable.subscribe({
  next(data) {
    console.log(data);
  },
  complete() {
    console.log('Completed');
  }
});

Output

Data fetched using Observable
Completed

Example 2: Handling Multiple Values Over Time

Using Promises

Handling multiple values over time with Promises involves chaining multiple Promises, which can be cumbersome.

const fetchFirst = () => {
  return new Promise(resolve => {
    setTimeout(() => {
      resolve('First value');
    }, 1000);
  });
};

const fetchSecond = () => {
  return new Promise(resolve => {
    setTimeout(() => {
      resolve('Second value');
    }, 2000);
  });
};

fetchFirst().then(value1 => {
  console.log(value1);
  return fetchSecond();
}).then(value2 => {
  console.log(value2);
});

Output

First value
Second value

Using Observables

Observables handle multiple values naturally.

import { Observable } from 'rxjs';

const multiValueObservable = new Observable(observer => {
  setTimeout(() => {
    observer.next('First value');
  }, 1000);

  setTimeout(() => {
    observer.next('Second value');
  }, 2000);

  setTimeout(() => {
    observer.complete();
  }, 3000);
});

multiValueObservable.subscribe({
  next(value) {
    console.log(value);
  },
  complete() {
    console.log('Completed');
  }
});

Output

First value
Second value
Completed

Example 3: Cancellation

Using Promises

Promises cannot be canceled once they are initiated.

const nonCancellablePromise = new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve('This cannot be canceled');
  }, 3000);
});

// You cannot cancel this promise once started.

Using Observables

Observables can be canceled by unsubscribing.

import { Observable, Subscription } from 'rxjs';

const cancellableObservable = new Observable(observer => {
  const timeoutId = setTimeout(() => {
    observer.next('This will not be logged');
    observer.complete();
  }, 3000);

  // Cleanup logic
  return () => {
    clearTimeout(timeoutId);
    console.log('Observable canceled');
  };
});

const subscription: Subscription = cancellableObservable.subscribe({
  next(value) {
    console.log(value);
  },
  complete() {
    console.log('Completed');
  }
});

// Cancel the Observable after 1 second
setTimeout(() => {
  subscription.unsubscribe();
}, 1000);

Output

Observable canceled

When to Use Promises vs. Observables

  • Use Promises:

    • When you need to handle a single asynchronous operation that resolves once (e.g., HTTP requests, reading a file).
    • When you want simplicity and don't need the advanced capabilities of Observables.
  • Use Observables:

    • When dealing with multiple values over time (e.g., user input, WebSocket connections, real-time data).
    • When you need to cancel the asynchronous operation.
    • When you need advanced operators for data transformation and composition.

Conclusion

Both Promises and Observables are powerful tools for managing asynchronous operations in JavaScript. Promises are simpler and great for single operations, while Observables offer more flexibility and are ideal for complex scenarios involving multiple values and real-time data streams. Understanding the strengths and use cases of each will help you make informed decisions in your development projects.

By mastering Promises and Observables, you can write more efficient, readable, and maintainable asynchronous code, improving the overall performance and user experience of your applications.


This content originally appeared on DEV Community and was authored by Shaikh AJ


Print Share Comment Cite Upload Translate Updates
APA

Shaikh AJ | Sciencx (2024-07-13T15:19:35+00:00) Observables vs Promises. Retrieved from https://www.scien.cx/2024/07/13/observables-vs-promises/

MLA
" » Observables vs Promises." Shaikh AJ | Sciencx - Saturday July 13, 2024, https://www.scien.cx/2024/07/13/observables-vs-promises/
HARVARD
Shaikh AJ | Sciencx Saturday July 13, 2024 » Observables vs Promises., viewed ,<https://www.scien.cx/2024/07/13/observables-vs-promises/>
VANCOUVER
Shaikh AJ | Sciencx - » Observables vs Promises. [Internet]. [Accessed ]. Available from: https://www.scien.cx/2024/07/13/observables-vs-promises/
CHICAGO
" » Observables vs Promises." Shaikh AJ | Sciencx - Accessed . https://www.scien.cx/2024/07/13/observables-vs-promises/
IEEE
" » Observables vs Promises." Shaikh AJ | Sciencx [Online]. Available: https://www.scien.cx/2024/07/13/observables-vs-promises/. [Accessed: ]
rf:citation
» Observables vs Promises | Shaikh AJ | Sciencx | https://www.scien.cx/2024/07/13/observables-vs-promises/ |

Please log in to upload a file.




There are no updates yet.
Click the Upload button above to add an update.

You must be logged in to translate posts. Please log in or register.