自动化构建工具——13.webpack 生产环境基本配置

生产环境基本配置

之前学习了各种文件的处理,接下来就需要汇总到一起,生成一个我们想要的生产环境的基本配置

const {
  resolve
} = require('path')
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
const OptimizeCssAssetsWebpackPlugin = require('optimize-css-assets-webpack-plugin')
const HtmlWebpackPlugin = require('html-webpack-plugin')
// 设置node.js环境变量:决定使用browserlist的哪个环境
process.env.NODE_ENV = 'development'
// 复用loader
const commonCssLoader = [
  // 提取成单独文件
  MiniCssExtractPlugin.loader,
  'css-loader',
  // 对样式进行兼容性处理
  // use数组中loader执行顺序:从右到左,从下到上依次执行,所以样式兼容性处理放在coo-loader后面
  {
    // 还需要在package.json中对browserlist进行设置,且如果需要使用开发环境配置,则要设置node.js环境变量,不然browserlist将默认使用production下的配置
    loader: 'postcss-loader',
    options: {
      ident: 'postcss',
      plugins: () => [require('postcss-preset-env')()]
    }

  }
]
module.exports = {
  entry: './src/js/index.js',
  output: {
    // 文件名
    filename: 'js/bulit.js',
    // 输出的文件目录
    path: resolve(__dirname, 'build')
  },
  module: {
    rules: [
      // 处理css样式文件
      {
        test: /\.css$/,
        use: [...commonCssLoader]
      },
      // 处理less文件
      {
        test: /\.less$/,
        use: [
          ...commonCssLoader,
          // 将less文件编译成css文件
          // 需要下载less-loader和less
          'less-loader'
        ]
      },
      /**
       * 正常来说,一个文件只能被一个loader处理。
       * 当一个文件要被多个loader处理,那么一定要指定loader执行的先后顺序
       *    先执行eslint 再执行 babel
       *      1. 因为eslint是执行语法检查的,如果语法出现错误,执行babel也没有意义
       *      2. babel会将ES6语法转换为ES5语法,一旦经过babel转换之后再进行eslint检查就会报语法错误
       */
      // 处理js文件
      {
        // 在package.json文件中eslintConfig配置使用airbnb规则
        test: /\.js$/,
        exclude: /node_modules/, // 排除检测node_modules的内容
        // 优先执行该loader,确保两个loader不会产生冲突
        enforce: 'pre',
        loader: 'eslint-loader',
        options: {
          // 自动修复检查到的问题
          fix: true
        }
      },
      // 对js做兼容性处理
      // 对js做兼容性处理
      {
        test: /\.js$/,
        exclude: /node_modules/,
        loader: 'babel-loader',
        options: {
          // 预设
          presets: [
            [
              '@babel/preset-env',
              {
                // 实现按需加载
                useBuiltIns: 'usage',
                // 指定core-js版本,可以到package.json查看
                corejs: {
                  version: 3
                },
                // 指定兼容哪些版本的浏览器
                targets: {
                  chrome: '60',
                  firefox: '50',
                  ie: '9'
                }
              }
            ]
          ]
        }
      },
      // 处理图片文件
      {
        test: /\.(jpg|png|gif)/,
        loader: 'url-loader',
        options: {
          // 图片大小小于8kb,就会被base64处理(8~12kb)
          // 优点:减少请求数量(减轻服务器压力)
          // 缺点:图片体积会更大(文件请求速度更慢)
          limit: 8 * 1024,
          // 给图片重命名
          // [hash: 10]取图片的hash的前10位
          // [ext]取文件原来扩展名
          name: '[hash:10].[ext]',
          // 输出路径
          outputPath: 'imgs',
          /**
           * 问题:因为url-loader默认使用ES6模块化解析,而html-loader引入图片是commonjs
           * 解析时会出问题:[object Module]
           * 解决:关闭url-loader的ES6模块化,使用commonjs解析
           */
          esModule: false,
        }
      },
      {
        test: /\.html$/,
        // 处理html文件中的img图片(负责引入img,从而能被url-loader进行处理)
        loader: 'html-loader'
      },
      // 处理其它文件
      {
        // 排除以下几种文件
        exclude: /\.(js|css|less|html|jpg|png|gif)/,
        loader: 'file-loader',
        options: {
          outputPath: 'media'
        }


      }

    ]
  },
  plugins: [
    new MiniCssExtractPlugin({
      // 对输出的文件进行重命名
      filename: 'css/built.css'
    }),
    // 压缩css
    new OptimizeCssAssetsWebpackPlugin(),
    // 处理html文件
    new HtmlWebpackPlugin({
      // 以指定html文件为模板创建新的html文件
      template: './src/index.html',
      // 压缩html文件
      minify: {
        // 压缩空格
        collapseWhitespace: true,
        // 去除注释
        removeComments: true
      }
    })
  ],
  // 生产环境下js会自动压缩
  mode: 'production'
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
东南亚位于我国倡导推进的“一带一路”海陆交汇地带,作为当今全球发展最为迅速的地区之一,近年来区域内生产总值实现了显著且稳定的增长。根据东盟主要经济体公布的最新数据,印度尼西亚2023年国内生产总值(GDP)增长5.05%;越南2023年经济增长5.05%;马来西亚2023年经济增速为3.7%;泰国2023年经济增长1.9%;新加坡2023年经济增长1.1%;柬埔寨2023年经济增速预计为5.6%。 东盟国家在“一带一路”沿线国家中的总体GDP经济规模、贸易总额与国外直接投资均为最大,因此有着举足轻重的地位和作用。当前,东盟与中国已互相成为双方最大的交易伙伴。中国-东盟贸易总额已从2013年的443亿元增长至 2023年合计超逾6.4万亿元,占中国外贸总值的15.4%。在过去20余年中,东盟国家不断在全球多变的格局里面临挑战并寻求机遇。2023东盟国家主要经济体受到国内消费、国外投资、货币政策、旅游业复苏、和大宗商品出口价企稳等方面的提振,经济显现出稳步增长态势和强韧性的潜能。 本调研报告旨在深度挖掘东南亚市场的增长潜力与发展机会,分析东南亚市场竞争态势、销售模式、客户偏好、整体市场营商环境,为国内企业出海开展业务提供客观参考意见。 本文核心内容: 市场空间:全球行业市场空间、东南亚市场发展空间。 竞争态势:全球份额,东南亚市场企业份额。 销售模式:东南亚市场销售模式、本地代理商 客户情况:东南亚本地客户及偏好分析 营商环境:东南亚营商环境分析 本文纳入的企业包括国外及印尼本土企业,以及相关上下游企业等,部分名单 QYResearch是全球知名的大型咨询公司,行业涵盖各高科技行业产业链细分市场,横跨如半导体产业链(半导体设备及零部件、半导体材料、集成电路、制造、封测、分立器件、传感器、光电器件)、光伏产业链(设备、硅料/硅片、电池片、组件、辅料支架、逆变器、电站终端)、新能源汽车产业链(动力电池及材料、电驱电控、汽车半导体/电子、整车、充电桩)、通信产业链(通信系统设备、终端设备、电子元器件、射频前端、光模块、4G/5G/6G、宽带、IoT、数字经济、AI)、先进材料产业链(金属材料、高分子材料、陶瓷材料、纳米材料等)、机械制造产业链(数控机床、工程机械、电气机械、3C自动化、工业机器人、激光、工控、无人机)、食品药品、医疗器械、农业等。邮箱:market@qyresearch.com

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值