React js with webpack4
- Authors
- Name
- Jignesh Sanghani
- @jignesh19961020
We can learn lots of thing in this tutorial but i assume that you have basic knowledge about below technologies
- npm
- reactjs
- webpack
I'll explain you step by step to setup your react project with webpack
Create folder blog-tutorial
mkdir blog-tutorial
Step 1: Project Initialization
First start with initializing project directory by below command
npm init
After the init process you can see some stuff in json like app name, author, dependencies, main script, etc ... are included in the package.json file Step 2: Download react and babel
let’s download necessary packages for react with babel dependencies
npm i react react-dom
Now on, all dependencies we install as dev dependency. Which we can do by npm option -D
or --save-dev
We have now react, the things we require now is babel which is a toolchain that is mainly used to convert ECMAScript 2015+ code into a backward compatible version of JavaScript in current and older browsers or environments. you can learn more about babel here
npm i -D @babel/core @babel/preset-env @babel/preset-react babel-loader style-loader css-loader
step-3: Create necessary directory and files Create src directory in the root directory Inside the src folder
- src /-
- Index.js
- Index.html
- components /-
- App.js
We created three file index.js
, index.html
, and App.js
inside components folder
For linux users
touch index.js
touch index.html
mkdir components
cd components
touch App.js
For windows users
type nul > index.js
type nul > index.html
mkdir components
cd components
type nul > App.js
import React from 'react';
import ReactDom from 'react-dom';
import App from './components/App';
ReactDom.render(<App />, document.getElementById('app'));
<html>
<head>
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Blog Tutorial</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" type="text/css" media="screen" href="css/main.css" />
</head>
<body>
<div id="app"></div>
</body>
</html>
import React, { Component } from 'react';
class App extends Component{
render(){
return( <div>
<h1> Hello App</h1>
</div>
);
}
}
export default App;
Step:4 configure .babelrc
file
Create .babelrc
file
Linux:
touch .babelrc
Windows:
type nul > .babelrc
.babelrc
file is babel configuration file you can learn more about them here
Since babel 7 they change preset-react to @babel/preset-react
likewise for env. Instead of es2015 babel use now env preset
{
"presets": [
"@babel/preset-react", "@babel/preset-env"
]
}
Step 5: Install webpack
Now, we install webpack
Webpack is an open-source JavaScript module bundler. Its main purpose is to bundle JavaScript files for usage in a browser, yet it is also capable of transforming, bundling, or packaging just about any resource or asset. Webpack takes modules with dependencies and generates static assets representing those modules. You can learn more about webpack from here(https://webpack.js.org/concepts/)
npm i -D webpack webpack-dev-server webpack-cli html-webpack-plugin mini-css-extract-plugin
We installed 2 plugin html-webpack-plugin
which generate index.html
file in dist folder from our template which is in src/index.html
And mini-css-extract-plugin
will generate optimize CSS file in dist/css
folder.
If you are using webpack 3 the install instead of text-css-extract-plugin of mini-css-extract-plugin Step 6: Configure webpack.config.js
Now the last thing remaining is to configure web pack
Create a file name: webpack.config.js
Linux:
touch webpack.config.js
Windows:
type nul > webpack.config.js
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
module.exports = {
entry: './src/index.js',
output: {
path: __dirname + "/dist",
filename: '[name].bundle.js',
chunkFilename: '[name].bundle.js',
sourceMapFilename :'[name].bundle.js.map'
},
module: {
rules:[
{
test: /.js$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader'
}
},
{
test: /.(sa|sc|c)ss$/,
use: [
{
loader: MiniCssExtractPlugin.loader,
options: {
publicPath: '../css/'
}
},
'css-loader',
'sass-loader',
],
}
]
},
plugins: [
new MiniCssExtractPlugin({
filename: 'css/[name].css',
chunkFilename: 'css/[id].css',
}),
new HtmlWebpackPlugin({
template: './src/index.html'
})
]
}
Above configuration, you can learn more about here Step 7: Build and Run project
At last, our react with webpack app ready to run
Hit below command
npm start
To build
npm run build
After building you can see your static code in dist folder in the root directory. you can visit my GitHub repo react-starter-with-webpack
If you want to start with electron with react then go my postBuild windows Application using Electron