码迷,mamicode.com
首页 > Web开发 > 详细

webpack 提取css成单独文件 css兼容性处理 压缩css

时间:2020-06-05 16:47:15      阅读:83      评论:0      收藏:0      [点我收藏+]

标签:mini   ini   ecs   dev   str   加载   --   需要   webpack   

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

 

webpack 提取css成单独文件 css兼容性处理 压缩css

标签:mini   ini   ecs   dev   str   加载   --   需要   webpack   

原文地址:https://www.cnblogs.com/hllzww/p/13050053.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!