使用webpack构建react项目

2 篇文章 0 订阅
1 篇文章 0 订阅

前言

本文介绍构建react项目相关的webpack配置
安装好reactreact-dom

npm安装指令

  • --save-dev表示只是在编译过程中所依赖的包,比如webpacksass-loaderbabale等,最后在webpack.config.jsdevDependencies中显示
  • --save表示在编译后运行时还需要依赖的包,比如reactreact-dom等,最后在dependencies部分显示。

react项目

  • 准备一个react项目,使用到了styled-components,react是基于react-hooks
  • 提前安装好webpackwebpack-cli
  • 创建好webpack.config.js.babelrc看情况,也可以直接在webpack.config.js中配置
    在这里插入图片描述

配置输入/输出文件

配置输入输出文件,使用webpack-dev-server启动打包好的文件

module.exports = {
    mode: 'production',
    entry: './src/index.js',//入口文件
    output: {//输出
        path: path.resolve(__dirname, 'dist'),
        filename: 'bundle.[contenthash].js'
    },
    devServer: {
        static: './dist',
        compress: true,
        port: 9000
    },
    module: {
        rules: []
    },
    plugins: [
        new HtmlWebpackPlugin({//运行入口文件
            favicon: './public/favicon.ico',
            template: './public/index.html',
            filename: 'index.html',
            manifest: './public/mainfest.json'
        }),
        new CleanWebpackPlugin({
            root: path.resolve(__dirname, 'dist')
        })
    ]
}

配置babel

  1. 安装
npm install --save-dev babel-loader @babel/preset-react @babel/preset-env @babel/plugin-transform-runtime
  1. 配置如下
{
    test: /(\.js|\.jsx)$/,
    exclude: /(node_modules)/,
    use: {
        loader: 'babel-loader',
        options: {
            presets: ['@babel/preset-react', '@babel/preset-env'],
            plugins: ['babel-plugin-styled-components', '@babel/plugin-transform-runtime']
        }
    }
},

配置图片加载

  1. 安装url-loader
npm install url-loader --save
  1. 编写webpack.config.js文件
{
   test: /\.(png|jpg|gif|jpeg)$/,
   use: [
       {
           loader: 'url-loader',
           options: {
               limit: 12000,
               // 打包到dist文件夹重命名
               name: 'img/[name].[hash:8].[ext]'
           }
       }
   ],
   exclude: /node_modules/
},

css文件加载配置

{
   test: /\.(css)$/,
   use: [
       'style-loader',
       'css-loader',
       'post-loader'
   ]
}

打包,启动环境

  "scripts": {
    "start": "webpack serve --open",
    "build": "webpack --config webpack.config.js",
  },

运行项目

npm run build
npm run start

访问http://localhost:9000/即可。

综上,初始化一个react项目常用到的pluginloader有:

  • loader:babel-loader、babel-core、@babel/preset-react、@babel/preset-envcss-loaderstyle-loaderurl-loader
  • plugin:html-webpack-pluginclean-webpack-plugin
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值