提取css成單獨文件
1.安裝插件並引入
npm install mini-css-extract-plugin -D
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
2.配置插件plugins
plugins: [ new HtmlWebpackPlugin({ template:'./src/index.html' }), new MiniCssExtractPlugin({ filename:'css/built.css'//對輸出的文件進行重命名,默認為main.css }) ],
3.修改loader文件
{ test:/\.css$/, use:[ //取代css-loader,提取js中css成單獨文件(注意) MiniCssExtractPlugin.loader, //將css文件整合到JS文件中 'css-loader', ] },
css兼容性處理
1.安裝插件
npm install postcss-loader postcss-preset-env -D
2.在module中配置postcss-loader並配置postcss-preset-env插件
{ test:/\.css$/, use:[ //取代css-loader,提取js中css成單獨文件 MiniCssExtractPlugin.loader, //將css文件整合到JS文件中 'css-loader', //css兼容性處理:postcss --> postcss-loader postcss-preset-env //幫postcss找到package.json中browserslist里面的配置,通過配置加載指定的css兼容性樣式 { loader:'postcss-loader', options: { ident: 'postcss',//默認配置 plugins: () => [ require('postcss-preset-env')() ] } } ] },
3.配置package.json中的browserslist
"browserslist":{ "development":[ "last 1 chrome version", "last 1 firefox version", "last 1 safari version" ], "production":[ ">0.1%", "not dead", "not op_mini all" ] }
4.為了使package.json中browserslist中的development環境生效,需要在webpack.config.js中配置環境,因為默認是生產環境,我們開發需要開發環境
const {resolve}=require('path') const HtmlWebpackPlugin = require('html-webpack-plugin') const MiniCssExtractPlugin = require('mini-css-extract-plugin') //設置node.js環境變量,默認是生產環境,配置后為開發環境; process.env.NODE_ENV = 'development';
壓縮css
1.安裝插件並引用
npm install optimize-css-assets-webpack-plugin -D
const OptimizeCssAssetsWebpackPlugin = require('optimize-css-assets-webpack-plugin')
2.在plugins中配置插件
plugins: [ new HtmlWebpackPlugin({ template:'./src/index.html' }), new MiniCssExtractPlugin({ filename:'css/built.css'//對輸出的文件進行重命名 }), //壓縮css文件 new OptimizeCssAssetsWebpackPlugin() ],