webpack生产环境下的配置
创始人
2025-01-10 02:09:03
0

css 处理

css提取

  1. 下载包

npm i -D mini-css-extract-plugin

  1. 配置
 module: {    rules: [      {        test: /\.css$/,        use: [          // 'style-loader', // 创建style标签,将样式加入js文件          MiniCssExtractPlugin.loader, // 提取js中的css成单独的文件          'css-loader',        ]      },     ]  },  plugins: [    new HtmlWebpackPlugin({      template: './src/index.html'    }),    new MiniCssExtractPlugin({      filename: 'css/budle.css'    })  ], 

css兼容性处理

  1. 下载包

npm i -D postcss-loader postcss-preset-env

  1. 配置

Webpack.config.js

 rules: [    {      test: /\.css$/,      use: [        // 'style-loader', // 创建style标签,将样式加入js文件        MiniCssExtractPlugin.loader, // 提取js中的css成单独的文件        'css-loader',        // css兼容性处理:postcss ---> postcss-loader  postcss-preset-env        // 帮postcss找到package.json中的browerslist里面的配置,通过配置加载指定的css兼容性样式        /**                  * "browserslist": {                  *   // 开发环境 --> 设置node环境变量: process.env.NODE_ENV = development 才能生效                     "development": [                     "last 1 chrome version",                     "last 2 firefox version",                     "last 1 safari version"                     ],                     // 生产环境:默认看生产环境                     "production":[                     "> 0.2%",                     "not dead",                     "not op_mini all"                     ]                 }                  */        {          loader: 'postcss-loader',          options: {            postcssOptions: {              plugins:  [                'postcss-preset-env'              ]            },          }        }      ]    },   ] 

package.json

 "browserslist": {     "development": [       "last 1 chrome version",       "last 2 firefox version",       "last 1 safari version"     ],     "production": [       "> 0.1%",       "not dead",       "not op_mini all"     ]   } 

压缩css

  1. 下载包

npm i css-minimizer-webpack-plugin -D

 plugins: [   // 压缩css   new CssMinimizerWebpackPlugin() ], 

js压缩

  1. mode设置为生产模式即可,生产环境自动压缩js

mode: "production"

html压缩

plugins: [   new HtmlWebpackPlugin({     template: './src/index.html',     minify: {       // 移除空格       collapseWhitespace: true,       // 移除注释       removeComments: true,     }   }), ] 

eslint

  1. 下载包

npm i -D eslint eslint-webpack-plugin eslint-plugin-import eslint-config-airbnb-base

  1. 配置

Webpack.config.js

 plugins: [    new ESLintWebpackPlugin({      exclude: '/node_modules/',      fix: true,    })  ], 

Package.json
根配置,配置eslint标准

"eslintConfig": {   "extends": "airbnb-base" } 

js兼容

  1. 下载包

npm i -D babel-loader @babel/preset-env @babel/core @babel/polyfill core-js

  1. 配置
module: {   rules: [      {        //  1. js兼容性处理: babel-loader @babel/core  @babel/preset-env        //  问题:babel只能转换基础的语法,如promise则不能进行转换        //  2. 全部兼容  @babel/polyfill        //  问题:可以解决兼容性问题,但是引入了所有的兼容性代码,体积太大        //  3. 需要做兼容性的处理就ok,按需加载---> core-js        test: /\.js$/,        exclude: /node_modules/,        loader: 'babel-loader',        options: {          // 预设: 指示babel做怎样的兼容性处理          presets: [[            '@babel/preset-env',            {              useBuiltIns: 'usage', //按需加载              corejs: {                version: 3, // 指定core-js版本              },              targets: {  // 指定兼容浏览器版本                chrome: '60',                firefox: '60',                ie: '9',                safari: '10',                edge: '17'              }            }          ]]        }      }   ] } 

在入口文件(src/index.js)引入@babel/polyfill

import '@babel/polyfill';

方案2和方案三选一种即可
方案2

module: {   rules: [       {        test: /\.js$/,        exclude: /node_modules/,        loader: 'babel-loader',        options: {          // 预设: 指示babel做怎样的兼容性处理          presets: [[            '@babel/preset-env',          ]]        }      }   ] } 

在入口文件引入 @babel/polyfill

import '@babel/polyfill';

方案3

module: {   rules: [      {        //  1. js兼容性处理: babel-loader @babel/core  @babel/preset-env        //  问题:babel只能转换基础的语法,如promise则不能进行转换        //  2. 全部兼容  @babel/polyfill        //  问题:可以解决兼容性问题,但是引入了所有的兼容性代码,体积太大        //  3. 需要做兼容性的处理就ok,按需加载---> core-js        test: /\.js$/,        exclude: /node_modules/,        loader: 'babel-loader',        options: {          // 预设: 指示babel做怎样的兼容性处理          presets: [[            '@babel/preset-env',            {              useBuiltIns: 'usage', //按需加载              corejs: {                version: 3, // 指定core-js版本              },              targets: {  // 指定兼容浏览器版本                chrome: '60',                firefox: '60',                ie: '9',                safari: '10',                edge: '17'              }            }          ]]        }      }   ] } 

相关内容

热门资讯

技法辅助!决战geo辅助!必备... 技法辅助!决战geo辅助!必备有辅助插件(有挂方法)1、该软件可以轻松地帮助玩家将决战geo辅助辅助...
相较于以往!闽游互动辅助器(辅... 相较于以往!闽游互动辅助器(辅助)总是存在有辅助器(新版有挂)一、闽游互动辅助器游戏安装教程牌型概率...
绝活儿辅助!新卡农辅助软件!关... 绝活儿辅助!新卡农辅助软件!关于是真的有辅助攻略(有挂猫腻)进入游戏-大厅左侧-新手福利-激活码辅助...
一直以来!乐酷大厅怎么安装(辅... 一直以来!乐酷大厅怎么安装(辅助)本来是有辅助app(有挂细节)1、很好的工具软件,可以解锁游戏的乐...
演示辅助!微乐河南小程序微乐辅... 演示辅助!微乐河南小程序微乐辅助脚本!揭露存在有辅助神器(讲解有挂)1、微乐河南小程序微乐辅助脚本透...
今天上午!科技实测情怀辅助(辅... 今天上午!科技实测情怀辅助(辅助)原来存在有辅助教程(有人有挂)1、科技实测情怀辅助辅助软件下载优化...
课程辅助!天天微友插件!解迷是... 课程辅助!天天微友插件!解迷是有辅助方法(有挂存在)1、首先打开天天微友插件辅助器下载最新版本,在天...
最新消息!四川麻将血战智能辅助... 最新消息!四川麻将血战智能辅助(辅助)切实是有辅助挂(有挂总结)亲,关键说明,四川麻将血战智能辅助透...
机巧辅助!潮友会鱼虾蟹骰子概率... 机巧辅助!潮友会鱼虾蟹骰子概率计算公式!关于是真的有辅助方法(有人有挂)1、潮友会鱼虾蟹骰子概率计算...
昨日!湖北卡五星有什么讲究(辅... 昨日!湖北卡五星有什么讲究(辅助)竟然存在有辅助器(有挂辅助)1)湖北卡五星有什么讲究免费钻石:进一...