美文网首页React让前端飞我们就爱程序媛
从零开始配置React应用开发环境

从零开始配置React应用开发环境

作者: D6K | 来源:发表于2017-08-24 17:39 被阅读165次

    使用create-react-app创建的React应用开发环境给了我们便利的同时也给我们很大的限制,最好的方式还是按照自己意愿去组合构建开发环境,形成一套适合自己或自己团队的可定制环境。

    在开始环境搭建之前得安装Node,Git等基础软件工具。创建工程目录,并用npm init -y初始化package.json文件。

    mkdir learn-react
    cd learn-react
    npm init -y
    

    安装webpack,webpack-dev-server,babel-core,babel-loader,babel-preset-env,babel-preset-react,html-webpack-plugin,clean-webpack-plugin等工具包和react, react-dom, prop-types等项目依赖包。编写打包配置文件webpack.config.js,并在package.json中增加运行命令。
    注意:其中webpack,babel-core,babel-preset,babel-preset-react,babel-loader是必须的,其他的可选。

    npm install --save-dev webpack webpack-dev-server  babel-core babel-loader babel-preset-env babel-preset-react  html-webpack-plugin clean-webpack-plugin 
    npm install --save react react-dom prop-types
    

    打包配置文件webpack.config.js

    const path = require('path');
    const HtmlWebpackPlugin = require('html-webpack-plugin'); //html模板文件引用插件
    const CleanWebpackPlugin = require('clean-webpack-plugin'); //删除目录插件
    
    module.exports = {
        resolve: {
            extensions:  ['.js','.jsx'] //解析文件类型
        },
        entry: './src/index.js', //打包入口
        //模块解析规则
        module: {
            rules: [
                {
                    test: /\.jsx?$/, // 解析文件类型
                    exclude: /node_modules/, //排除文件夹或文件
                    use: {
                        loader: "babel-loader", //解析插件
                        options: {
                            presets: ["env", "react"] //解析规则集,env对应babel-preset-env,主要用于JavaScript新特性适配,react对应babel-preset-react,主要用于jsx语法的解析                  
                        }
                    }
                }
            ]
        }, 
        devtool: 'inline-source-map', // 报错代码追踪
        devServer: {
            contentBase: './dist' //服务启动基础目录
        },
        plugins: [
            new CleanWebpackPlugin(['dist']), //删除dist目录
            new HtmlWebpackPlugin({
                title: 'Development', //页签名
                template: 'template/index.html', // 模板文件
                inject: 'body' // 生成文件自动插入方式
            })
        ],
        output: {
            filename: "[name]-bundle.js", //生成文件名
            path: path.resolve(__dirname, 'dist') //生成文件存放目录
        }
    };
    

    项目依赖文件package.json

    "description": "",
      "main": "index.js",
      "scripts": {
        "start": "webpack-dev-server --open",
        "build": "webpack",
      },
      "keywords": [
        "react"
      ],
      "author": "Dreamer King",
      "license": "MIT",
      "dependencies": {
        "react": "^15.6.1",
        "react-dom": "^15.6.1",
         "prop-types": "^15.5.10"
      },
      "devDependencies": {
        "babel-core": "^6.26.0",
        "babel-loader": "^7.1.2",
        "babel-preset-env": "^1.6.0",
        "babel-preset-react": "^6.24.1",
        "clean-webpack-plugin": "^0.1.16",
        "html-webpack-plugin": "^2.30.1",
        "webpack": "^3.5.5",
        "webpack-dev-server": "^2.7.1"
      }
    }
    

    其中,start命令以npm start运行启动开发环境,而build命令是打包,以npm run build运行。
    到此,基础的开发环境配置完毕,可以编写代码啦!
    附项目的目录结构如下:

    项目目录结构

    相关文章

      网友评论

      • 月池沽酒:求图片里的字体名称!!
        月池沽酒:@D6K 好的,谢谢
        D6K:@月池沽酒 忘记了,自己找找看看,内置的字体

      本文标题:从零开始配置React应用开发环境

      本文链接:https://www.haomeiwen.com/subject/clfedxtx.html