Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/imranhsayed/javascript-concepts
:mortar_board: A demo app for JavaScript Concepts
https://github.com/imranhsayed/javascript-concepts
async-await javascript promise-all promise-library promises try-catch
Last synced: 3 months ago
JSON representation
:mortar_board: A demo app for JavaScript Concepts
- Host: GitHub
- URL: https://github.com/imranhsayed/javascript-concepts
- Owner: imranhsayed
- Created: 2019-05-29T18:22:16.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-03-26T10:41:29.000Z (10 months ago)
- Last Synced: 2024-10-03T09:24:07.630Z (4 months ago)
- Topics: async-await, javascript, promise-all, promise-library, promises, try-catch
- Language: JavaScript
- Homepage:
- Size: 396 KB
- Stars: 13
- Watchers: 3
- Forks: 2
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# JavaScript Concepts :mortar_board:
## Description :clipboard:
> A demo app for JavaScript Concept## Installation :wrench:
1. Clone this repo by running `git clone https://github.com/imranhsayed/javascript-concepts`
2. `cd javascript-concepts`
3. `cd branch-name`
4. `npm install`
5. `npm run server`## Branch Information :link:
#### 1. [callbacks]()
* Callbacks add complexity and readability issue. And its messy to chain the tasks
#### 2. [promises](https://github.com/imranhsayed/javascript-concepts/tree/promises)
* A promise is an object that represent the eventual( future ) completion(or failure) of an asynchronous operation, and its future result value.
Promises are thin abstraction around call backs. ( e.g. `readFile.( 'config.json' ).then(...).catch(...)` )
In below example what you pass in resolve will be available as value in `.then(( value )=> ...)````ruby
var promise1 = new Promise(function(resolve, reject) {
setTimeout(function() {
resolve('foo');
}, 300);
});promise1.then(function(value) {
console.log(value);
// expected output: "foo"
});
```3. [async-await](https://github.com/imranhsayed/javascript-concepts/tree/async-await)
##### Async - declares an asynchronous function `(async function someName(){...})`.
* Automatically transforms a regular function into a Promise.
* When called async functions resolve with whatever is returned in their body.
* Async functions enable the use of `await`.##### Await - pauses the execution of async functions. `(const result = await someAsyncCall();)`.
* When placed in front of a Promise call, await forces the rest of the code to wait until that Promise finishes and returns a result.
* Await works only with Promises, it does not work with callbacks.
* Await can only be used inside async functions.##### Async Await Example
```ruby
async function getTodoData() {
const todoData = await fetch( 'https://jsonplaceholder.typicode.com/todos/' );
return todoData;
}getTodoData()
.then( res => res.json() )
.then( ( result ) => {
console.warn( result );
} );
```##### Try and Catch Method
```ruby
async function getPosts() {
try {
const postsData = await await fetch( 'https://jsonplaceholder.typicode.com/posts/' );
return postsData;
}
catch ( error ) {
console.warn( 'error', error );
}
}getPosts()
.then( res => res.json() )
.then( ( result ) => {
console.warn( result );
} );```
## Fetch Example
```ruby
fetch('https://example.com/wp-json/wp/v2/posts')
.then(
function(response) {
if (response.status !== 200) {
console.log('Looks like there was a problem. Status Code: ' +
response.status);
return;
}// Examine the text in the response
response.json().then(function(data) {
console.log(data);
});
}
)
.catch(function(err) {
console.log('Fetch Error :-S', err);
});
```## Useful Links :link:
1. [async-await concept blog](https://tutorialzine.com/2017/07/javascript-async-await-explained)
2. [try-catch](https://www.w3schools.com/js/js_errors.asp)
3. [Promise.all()](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/all)## Instructions :point_right:
## Common Commands :computer:
1. `npm run dev` starts a webpack dev server at [http://localhost:8080](http://localhost:8080)
2. `npm run prod` runs build for production in dist directory.## Built With :zap:
1. Node
2. Express
3. ES6
4. Webpack
5. Babel## Author :bust_in_silhouette:
* **[Imran Sayed](https://codeytek.com)**
## License
[![License](http://img.shields.io/:license-mit-blue.svg?style=flat-square)](http://badges.mit-license.org)
- **[MIT license](http://opensource.org/licenses/mit-license.php)**