Why Parcel as a bundler is better than Webpack?

in #utopian-io7 years ago (edited)

I had been using webpack for more than a few months. The pain of using webpack was that everytime when I need to setup, I need to read through the documents and my old source again and again.

Disclaimer: Webpack is amazing tool when you want to make some sophisticated setup, but for beginner, webpack is way too overwhelming to get started. I would recommend using parcel to get started learning about javascript front end library or framework.


32607881.png
parcel-bundler

Below are my sample source code to setup my webpack workflow.

Screen Shot 2018-02-07 at 11.19.27 AM.png

Sample of webpack config file

What if I tell you, this is no longer a pain when you use Parcel. Parcel is easy way to setup your Web App Work flow.

In this tutorial, I will be using React app as an example to show how easy it is to setup with parcel.

What Will I Learn?

  • Setup parcel workflow with React

Requirements

  • Basic Understanding of React
  • NPM and Node installed

Difficulty

Intermediate

Tutorial Contents

What is Parcel?

According to the Parcel team, they said that Parcel is Blazing fast, zero configuration web application bundler.

I would say it is the easiest way to get started for a bundler instead of using complicated library like webpack.

When I use webpack, Hot Module Reload was a bit tricky to setup, and making css work also required some research. This lead to the next section, why parcel.

Why Parcel?

  • Easy to setup
  • Hot Module Reload attached by default (no configuration)
  • The output error log is nicer
  • CSS Setup by default

Start using Parcel

Initialize project

The project is initialize by installing all the required library.

  • npm init
  • Install React and ReactDOM
    npm install react react-dom
  • Install Parcel
    npm install --save-dev parcel-bundler
  • Install Babel (Using react-app)
    npm install --save-dev babel-preset-react

Setup babel

create a file call .babelrc, and the setup we use is the easiest way to get started.

{
    "presets": ["react-app"]
}

File Structure

The final file structure look like this.

/
|- node_modules/
|- .babelrc
|- index.html
|- package-lock.json
|- package.json
|- src/
    |- index.js

Setup some HTML and React

Create an index.html, setup a div with id of "app", then attach the js file.

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>React with Parcel</title>
</head>
<body>
  <div id="app"></div>
  <script src="src/index.js"></script>
</body>
</html>

Create src/index.js file, where you start using the React App.

import React from 'react';
import ReactDOM from 'react-dom';

ReactDOM.render(
  <h1>Hello Parcel and React</h1>,
  document.querySelector('#app')
  );

Setup a script in package.json

In package.json file, add 2 lines of codes into scripts to be use

"scripts": {
    "start": "parcel index.html",
    "build": "parcel build index.html"
},

To start a development server, simply just run npm run start.

Screen Shot 2018-02-07 at 11.42.03 AM.png
The server serves at localhost:1234

To start a production file, simply just run npm run build, and it will generate a dist file that contains all the necessary file to use in production. Parcel automatically minified your file which is ready to be use in production.

Recap

Recap

Recap

Isn't parcel much easier than webpack? No more spending time reading docs on which webpack plugin to attach to do css, or any other things.

With this setup, basically you have done all it needs to start a project. You can use CSS, Hot Module Reload, Minified JS and CSS in production, Babel setup which can transpile React into JS that can be understand by browser.

With this setup, basically you have done all it needs to start a project. You can use CSS, Hot Module Reload, Minified JS and CSS in production, Babel setup which can transpile React into JS that can be understand by browser.

With this setup, basically you have done all it needs to start a project. You can use CSS, Hot Module Reload, Minified JS and CSS in production, Babel setup which can transpile React into JS that can be understand by browser.



Posted on Utopian.io - Rewarding Open Source Contributors

Sort:  

@superoo7-dev, I like your contribution to open source project, so I upvote to support you.

Your contribution cannot be approved because it does not follow the Utopian Rules.

You can contact us on Discord.
[utopian-moderator]