zoukankan      html  css  js  c++  java
  • webpack4

    遇到一个坑,查了好久才找出解决办法,话不说多,问题如下:

    ERROR in ./src/css/b.css (./node_modules/_css-loader@4.3.0@css-loader/dist/cjs.js!./node_modules/_postcss-loader@4.0.1@postcss-loader/dist/cjs.js??postcss!./src/css/b.css)
    Module build failed (from ./node_modules/_postcss-loader@4.0.1@postcss-loader/dist/cjs.js):
    ValidationError: Invalid options object. PostCSS Loader has been initialized using
    an options object that does not match the API schema.
    - options has an unknown property 'plugins'. These properties are valid:
    object { postcssOptions?, execute?, sourceMap? }
    at validate (C:UsersAdministratorDesktopSep... ode_modules\_schema-utils@2.7.1@schema-utilsdistvalidate.js:98:11)
    at Object.loader (C:UsersAdministratorDesktopSep... ode_modules\_postcss-loader@4.0.1@postcss-loaderdistindex.js:43:28)

    翻译:

    ValidationError:无效的选项对象。PostCSS加载程序已使用初始化
    
    与API架构不匹配的options对象。
    
    -options具有未知属性“plugins”。这些属性有效:{ postcssOptions?, execute?, sourceMap? }

    出问题的配置:

    const { resolve } = require("path");
    const HtmlWebpackPlugin = require("html-webpack-plugin");
    const MiniCssExtractPlugin = require("mini-css-extract-plugin");
    
    module.exports = {
        entry: "./src/js/index.js",
        output: {
            filename: "js/built.js",
            path: resolve(__dirname, "build")
        },
        module: {
            rules: [{
                test: /.css$/,
                use: [
                    MiniCssExtractPlugin.loader,
                    "css-loader",
                    {
                        loader: 'postcss-loader', 
                        options: { 
                            ident: 'postcss', 
                            plugins: [
                                //postcss的插件
                                require('postcss-preset-env')()
                            ]
                        }
                    }
                ]
            }]
        },
        plugins: [
            new HtmlWebpackPlugin({
                template: './src/index.html'
            }),
            new MiniCssExtractPlugin({
                filename: 'css/built.css'
            })
        ],
        mode: "development"
    }

    问题原因:官方更新了配置,所以以前的方法就不行了

    新配置:

    const { resolve } = require("path");
    const HtmlWebpackPlugin = require("html-webpack-plugin");
    const MiniCssExtractPlugin = require("mini-css-extract-plugin");
    
    module.exports = {
        entry: "./src/js/index.js",
        output: {
            filename: "js/built.js",
            path: resolve(__dirname, "build")
        },
        module: {
            rules: [{
                test: /.css$/,
                use: [
                    MiniCssExtractPlugin.loader,
                    "css-loader",
                    {
                        loader: 'postcss-loader',
                    }
                ]
            }]
        },
        plugins: [
            new HtmlWebpackPlugin({
                template: './src/index.html'
            }),
            new MiniCssExtractPlugin({
                filename: 'css/built.css'
            })
        ],
        mode: "development"
    }

    新建文件 postcss.config.js

     内容为:

    module.exports = {
        plugins: [
            require('postcss-preset-env')
        ]
    }

    再次打包运行,css代码由  打包为  ,完成。

     最后:package.json配置也发一下

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

    如果是通过视频进来的,并且有帮助的话请留言+1,让我知道这篇文章帮到了多少人,谢谢

    参考链接:

      类似问题链接:https://blog.csdn.net/weixin_43932098/article/details/102784887

      官方最新配置链接:https://github.com/postcss/postcss/blob/master/docs/README-cn.md

      browserslist配置链接: https://www.jianshu.com/p/bd9cb7861b85

  • 相关阅读:
    反应堆模式
    ABP领域层——仓储(Repositories)
    如何使用ASP.NET Web API OData在Oracle中使用Entity Framework 6.x Code-First方式开发 OData V4 Service
    dapper的Dapper-Extensions用法(一)
    VisualStudio 怎么使用Visual Leak Detector
    Visual Studio Code开发TypeScript
    Topshelf创建Windows服务
    ENode框架初始化
    知已者明(转)
    配置静态监听解决ORA-12514错误的案例(转)
  • 原文地址:https://www.cnblogs.com/xihailong/p/13639160.html
Copyright © 2011-2022 走看看