首頁 >web前端 >前端問答 >範例解析webpack提取css為單獨檔案(附程式碼)

範例解析webpack提取css為單獨檔案(附程式碼)

WBOY
WBOY轉載
2022-08-09 13:48:152088瀏覽

本篇文章為大家帶來了關於javascript的相關知識,其中主要介紹了關於webpack提取css為單獨文件的相關問題,包括了css兼容性處理以及壓縮css等內容,下面一起來看一下,希望對大家有幫助。

範例解析webpack提取css為單獨檔案(附程式碼)

【相關推薦:javascript影片教學web前端

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

【相關影片教學推薦:vuejs入門教學web前端入門

以上是範例解析webpack提取css為單獨檔案(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除