webpack 提取css成單獨文件 css兼容性處理 壓縮css


提取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()
    ],

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM