教程:从零开始使用webpack 4, Babel 7创建一个React项目(2019)

教程:从零开始使用webpack 4, Babel 7创建一个React项目(2019)

你会在本篇学到什么

  1. 如何安装配置webpack
  2. 如何安装配置babel
  3. 如何安装react
  4. 如何创建两种React Component --- 容器/展示组件
  5. 在html文件中引用webpack生成的bundle文件
  6. 如何安装使用webpack dev server

初始化项目

首先我们先给项目创建一个文件夹 webpack-react-tutorial:

mkdir webpack-react-tutorial && cd webpack-react-tutorial

接着在这个文件夹下创建一个src的子文件夹:

mkdir -p src

初始化项目:

npm init -y 

如何安装配置webpack

webpack

webpack是一款非常有用的前端打包工具,了解如何使用它是React开发者的基础,因为webpack可以将React组件转化成几乎所有浏览器都可以运行的JS code。

让我们先来安装它:

npm i webpack --save-dev

你可能会需要webpack-cli,所以也先装上

npm i webpack-cli --save-dev

接着在package.json里添加webpack的指令

"scripts": {
  "build": "webpack --mode production"
}

到目前为止还不需要写webpack的配置文件。

老版的webpack会自动去找配置文件,但是从webpack 4之后,你就需要自己去匹配需要的配置文件了。

下面我们来安装和配置Babel来编译我们的代码。

初始化Babel

为什么要使用Babel?

React Component大多是用JS ES6语法来写的,而浏览器没办法运行ES6的语法,所以就需要工具来将ES6的代码转化成浏览器可以运行的代码(通常是es5的语法)。

webpack本身是不会做这件事情的,需要靠转换器:loader。

一个webpack loader作用就是把输入进去的文件转化成指定的文件格式输出。其中babel-loader负责将传入的es6文件转化成浏览器可以运行的文件

babel-loader需要利用Babel,所以需要预先将Babel配置好。

  1. babel preset env:将ES6的代码转成ES5(注意:babel-preset-es2015已经被废弃了)

2.babel preset react: 将JSX语法编译成JS

接着安装这两个依赖:

npm i @babel/core babel-loader @babel/preset-env @babel/preset-react --save-dev

不要忘了配置Babel! 首先要在webpack-react-tutorial文件夹里新建一个文件.babelrc,内容为

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

到这个时候,就可以写一小部分webpack的配置文件了。

创建一个新的文件webpack.config.js,内容为

const path = require('path');

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist')
  }
 
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        use: {
          loader: "babel-loader"
        }
      }
    ]
  }
};

这个webpack的配置很简单。意思就是所有以.js结尾的文件都会用babel-loader把ES6编译转化成ES5的文件。

同时它定义了输入文件的路径为 src/index.js,输出为dist/bundle.js。webpack 4里这两行代码你不写也行,webpack会默认帮你加,但是为了代码可读性,我们还是把它加上。

配置完成之后,我们就可以开始写React 组件了。

写React组件

这里会写两种React组件:容器、展示组件。如果不了解这两种组件概念的同学可以先了解一下。

简单来说: 容器跟展示组件是React组件的两种模式。

容器组件: 一般比较重数据处理的逻辑会写在这,比如监听外界传入(例如redux) state的变化,或者处理组件内部的state,等等。

展示组件:顾名思义,就是仅仅用来展示的。它一般都是一个纯箭头函数,接受容器组件通过props传来的数据,然后展示我们希望展示的html结构。

在下面的例子中,你会看到它们长啥样。

在本节中,我们来创建只有text input 的超级简单的React表单。

首先先把React库引进来:

npm i react react-dom --save

然后创建两个子文件夹来分别放React 容器/展示组件

mkdir -p src/js/components/{container,presentational}

接着我们来写一个容器组件,它有下面的特点

  1. 有自己的state

2. 渲染一个html表单

将这个容器组件放在container里

touch src/js/components/container/FormContainer.js

容器组件的代码如下:

import React, { Component } from "react";
import ReactDOM from "react-dom";

class FormContainer extends Component {
  constructor() {
 super();

 this.state = {
      title: ""
 };
 }

  render() {
 return (
 
); } } export default FormContainer;

到目前为止,这个组件还没啥用,它只是一个包裹着子展示组件的外壳。

所以我们来定义一下子组件Input吧。

我们知道html input有下列的属性:

  • type
  • class
  • id
  • value
  • required

所有的这些属性都由容器组件通过props传给它,这种组件叫做controlled component。

写一个react组件,最好给它加上Prop Types,这样一来可以做输入的数据类型检测,二来别人用你的组件,可以很快知道这个组件需要什么input

安装prop-types

npm i prop-types --save-dev

接着写这个展示组件

import React from "react";
import PropTypes from "prop-types";
const Input = ({ label, text, type, id, value, handleChange }) => (
  
); Input.propTypes = { label: PropTypes.string.isRequired, text: PropTypes.string.isRequired, type: PropTypes.string.isRequired, id: PropTypes.string.isRequired, value: PropTypes.string.isRequired, handleChange: PropTypes.func.isRequired }; export default Input;

到这一步我们就可以在容器组件里渲染Input这个子组件了

import React, { Component } from "react";
import ReactDOM from "react-dom";
import Input from "../presentational/Input";
class FormContainer extends Component {
  constructor() {
    super();
    this.state = {
      seo_title: ""
    };
    this.handleChange = this.handleChange.bind(this);
  }
  handleChange(event) {
    this.setState({ [event.target.id]: event.target.value });
  }
  render() {
    const { seo_title } = this.state;
    return (
      
); } } export default FormContainer;

写好组件之后,就可以用webpack来打包这些代码啦。

由于前面我们已经定义了webpack入口文件是 ./src/index.js

所以我们先创建一个index.js文件,在里面引入React组件

import FormContainer from "./js/components/container/FormContainer";

写好之后,激动人心的时刻到了!

我们终于可以通过运行

npm run build

来生成打包文件,由于我们在配置里定义了输出文件为:dist/bundle.js,所以一切顺利的话, 你现在应该可以看到一个新生成的dist文件,里面有一个bundle.js文件。

在HTML文件引入bundle

为了展示我们的React组件,我们需要让webpack生成一个html文件。上面我们生成的bundle.js就会放在这个html文件的

你可能感兴趣的:(前端,程序员,互联网,IT,编程)