详解如何用webpack4从零开始构建react开发环境


Posted in Javascript onJanuary 27, 2019

项目文件准备:

执行npm init,然后创建如下图所示的文件。

详解如何用webpack4从零开始构建react开发环境

在index.html里面添加

<!DOCTYPE html>
<html>
 <head>
  <title>The Minimal React Webpack Babel Setup</title>
 </head>
 <body>
  <div id="app"></div>
  <script src="./bundle.js"></script>
 </body>
</html>

在webpack.config.js里面添加

module.exports = {
 entry: './src/index.js',
 output: {
  path: __dirname + '/dist',
  publicPath: '/',
  filename: 'bundle.js'
 },
 devServer: {
  contentBase: './dist'
 }
};

在package.json里面添加

"scripts": {
  "start": "webpack-dev-server --config ./webpack.config.js --mode development"
 },

这样,当执行npm start的时候,就会使用webpack-dev-server把index.js相关文件打包,生成bundle.js,这时候浏览器会打开一个窗口,执行index.html(contentBase里面定义了),又因为index.html里面引入了bundle.js,就可以把压缩后的js文件执行起来。当然引入bundle.js这一步可以由我们强大的html-webpack-plugin完成。

安装依赖

npm install --save-dev webpack webpack-dev-server webpack-cli
npm install --save-dev @babel/core @babel/preset-env
npm install --save-dev babel-loader
npm install --save-dev @babel/preset-react

配置babel

在根目录下新建.babelrc文件,然后添加

{
 "presets": [
  "@babel/preset-env",
  "@babel/preset-react"
 ]
}

在webpack.config.js里面添加babel-loader配置

module.exports = {
 ...
 module: {
  rules: [
   {
    test: /\.(js|jsx)$/,
    exclude: /node_modules/,
    use: ['babel-loader']
   }
  ]
 },
 resolve: {
  extensions: ['*', '.js', '.jsx']
 }
 ...
};

引入react

npm install --save react react-dom

修改index.js: 这个ReactDOM.render就是把元素渲染到index.html里面id为'app'的元素厦门。在实际开发中,我们会把app.js渲染到这里,然后在app.js里面写redux,react-router构成的页面的起点。

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

const title = 'My Minimal React Webpack Babel Setup';

ReactDOM.render(
 <div>{title}</div>,
 document.getElementById('app')
);

配置react热加载

npm install --save-dev react-hot-loader

webpack.config.js

const webpack = require('webpack');

module.exports = {
 ...
 plugins: [
  new webpack.HotModuleReplacementPlugin()
 ],
 devServer: {
  contentBase: './dist',
  hot: true
 }
 ...
};

修改index.js

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

const title = 'My Minimal React Webpack Babel Setup';

ReactDOM.render(
 <div>{title}</div>,
 document.getElementById('app')
);

+ module.hot.accept();

这个时候执行npm start,就可以在浏览器访问http://localhost:8080看到Index.html里面的内容啦啦。参考链接:
https://www.robinwieruch.de/minimal-react-webpack-babel-setup/#babel-react-setup

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
如何设置一定时间内只能发送一次请求
Feb 28 Javascript
js中 javascript:void(0) 用法详解
Aug 11 Javascript
jQuery自定义滚动条完整实例
Jan 08 Javascript
AngularJs 指令详解及示例代码
Sep 01 Javascript
easyui datagrid 大数据加载效率慢,优化解决方法(推荐)
Nov 09 Javascript
浅析JavaScript中break、continue和return的区别
Nov 30 Javascript
微信小程序 实战程序简易新闻的制作
Jan 09 Javascript
使用travis-ci如何持续部署node.js应用详解
Jul 30 Javascript
详解vue文件中使用echarts.js的两种方式
Oct 18 Javascript
JQuery常见节点操作实例分析
May 15 jQuery
Vue 列表上下过渡效果的实例代码
Jun 25 Javascript
jQuery实现日历效果
Sep 11 jQuery
vue中轮训器的使用
Jan 27 #Javascript
Vue组件教程之Toast(Vue.extend 方式)详解
Jan 27 #Javascript
JavaScript变量提升和严格模式实例分析
Jan 27 #Javascript
超详细动手搭建一个VuePress 站点及开启PWA与自动部署的方法
Jan 27 #Javascript
PWA介绍及快速上手搭建一个PWA应用的方法
Jan 27 #Javascript
原生JS检测CSS3动画是否结束的方法详解
Jan 27 #Javascript
原生JS实现的跳一跳小游戏完整实例
Jan 27 #Javascript
You might like
php方法调用模式与函数调用模式简例
2011/09/20 PHP
php 模拟POST提交的2种方法详解
2013/06/17 PHP
js数字输入框(包括最大值最小值限制和四舍五入)
2009/11/24 Javascript
javascript学习笔记(十二) RegExp类型介绍
2012/06/20 Javascript
js 判断计算字符串长度/判断空的简单方法
2013/08/05 Javascript
Nodejs+express+html5 实现拖拽上传
2014/08/08 NodeJs
Javascript基础教程之break和continue语句
2015/01/18 Javascript
axios取消请求的实践记录分享
2018/09/26 Javascript
你了解vue3.0响应式数据怎么实现吗
2019/06/07 Javascript
使用Vue.set()方法实现响应式修改数组数据步骤
2019/11/09 Javascript
JavaScript Array.flat()函数用法解析
2020/09/02 Javascript
Python实现删除文件但保留指定文件
2015/06/21 Python
python追加元素到列表的方法
2015/07/28 Python
python音频处理用到的操作的示例代码
2017/10/27 Python
解决python 未发现数据源名称并且未指定默认驱动程序的问题
2018/12/07 Python
解决Python中定时任务线程无法自动退出的问题
2019/02/18 Python
Python环境Pillow( PIL )图像处理工具使用解析
2019/09/12 Python
TensorFLow 变量命名空间实例
2020/02/11 Python
python爬虫学习笔记之pyquery模块基本用法详解
2020/04/09 Python
解决redis与Python交互取出来的是bytes类型的问题
2020/07/16 Python
Python字典取键、值对的方法步骤
2020/09/30 Python
CSS3正方体旋转示例代码
2013/08/08 HTML / CSS
使用html5新特性轻松监听任何App自带返回键的示例
2018/03/13 HTML / CSS
Dyson加拿大官方网站:购买戴森吸尘器,风扇,冷热器及配件
2016/10/26 全球购物
Sunglasses Shop丹麦:欧洲第一的太阳镜在线销售网站
2017/10/22 全球购物
介绍一下如何利用路径遍历进行攻击及如何防范
2014/01/19 面试题
采购员的工作职责
2013/12/26 职场文书
应届毕业生自我鉴定范文
2013/12/27 职场文书
企业消防安全制度
2014/02/02 职场文书
公司营业员的自我评价
2014/03/04 职场文书
写字楼租赁意向书
2014/07/30 职场文书
学校党员对照检查材料
2014/08/28 职场文书
秦兵马俑导游词
2015/02/02 职场文书
关于分班的感言
2015/08/04 职场文书
小组口号霸气押韵
2015/12/24 职场文书
http通过StreamingHttpResponse完成连续的数据传输长链接方式
2022/02/12 Python