配置React项目的webpack

src文件夹
配置React项目的webpack_第1张图片
index.html
配置React项目的webpack_第2张图片

webpack基础配置
安装webpack-dev-server、html-webpack-plugin、react、react-dom(react相关的包不加-D)、babel-loader、@babel/core(注意版本兼容问题)

package.json
配置React项目的webpack_第3张图片
配置webpack.config.js,安装@babel/preset-react和@babel/preset-env

const HtmlWebpackPlugin=require('html-webpack-plugin');

module.exports={
     
    mode:'development',
    entry:'./src/index.js',
    module:{
     
        rules:[
            {
     
                test:/\.(js|jsx)$/,
                use:[
                    {
     
                        loader:'babel-loader',
                        options:{
     
                            presets:[
                                '@babel/preset-react',
                                '@babel/preset-env'
                            ]
                        }
                    }
                ]
            }
        ]
    },
    plugins:[
        new HtmlWebpackPlugin({
     
            template:'./src/index.html'
        })
    ]
}

配置index.js后执行yarn dev结果如下:
配置React项目的webpack_第4张图片
配置React项目的webpack_第5张图片
配置index.jsx
配置React项目的webpack_第6张图片
在index.js中导入index.jsx,替换内容
配置React项目的webpack_第7张图片
配置React项目的webpack_第8张图片
最后添加样式
安装style-loader、css-loader、less-loader后配置webapck.config.js
配置React项目的webpack_第9张图片

完整webpack.config.js如下:

const HtmlWebpackPlugin=require('html-webpack-plugin');

module.exports={
     
    mode:'development',
    entry:'./src/index.js',
    module:{
     
        rules:[
            {
     
                test:/\.(js|jsx)$/,
                use:[
                    {
     
                        loader:'babel-loader',
                        options:{
     
                            presets:[
                                '@babel/preset-react',
                                '@babel/preset-env'
                            ]
                        }
                    }
                ]
            },
            {
     
                test:/\.css$/,
                use:['style-loader','css-loader']
            },
            {
     
                test:/\.less$/,
                use:['style-loader','css-loader','less-loader']
            }
        ]
    },
    plugins:[
        new HtmlWebpackPlugin({
     
            template:'./src/index.html'
        })
    ]
}

base.less
在这里插入图片描述
index.less
配置React项目的webpack_第10张图片
将index.less引入到index.jsx中就Over啦~
配置React项目的webpack_第11张图片
配置React项目的webpack_第12张图片

你可能感兴趣的:(webpack,react)