Taro Error: chunk common [mini-css-extract-plugin]

目录

一、问题描述

二、解决方案


一、问题描述

taro项目编译时抛出一下异常:

Error: chunk common [mini-css-extract-plugin] Conflicting order. Following module has been added: * css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[4].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[4].oneOf[0].use[2]!./node_modules/@nutui/icons-react-taro/dist/style_iconfont.css despite it was not able to fulfill desired ordering with these modules: * css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[4].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[4].oneOf[0].use[2]!./node_modules/@nutui/nutui-react-taro/dist/esm/Space/style/style.css - couldn't fulfill desired order of chunk group(s) pages/test1/index1 - while fulfilling desired order of chunk group(s) pages/test2/index2

查阅资料后得知:

当前警告是由 mini-css-extract-plugin 这个插件抛出的,该插件主要是将 CSS 样式抽离出来到一个文件内,它的特点是不会重复编译 CSS 文件。所以引起这些警告的原因就是我们在项目中引用组件的时候引用的顺序不同,导致该插件遇到了编译过的 CSS 文件,所以才会抛出警告。

用案例阐述问题形成原因:

javascript 复制代码
import React, {useState} from 'react';
import Taro from "@tarojs/taro";
import {Text, View, Image} from '@tarojs/components';
import {IconFont} from "@nutui/icons-react-taro"; // 1
import {Calendar, Cell, Space, Price} from "@nutui/nutui-react-taro"; // 2

const Index1 = () => {
  return <View>Index1 Page</View>
}
export default Index1
javascript 复制代码
import React, {useState} from 'react';
import Taro from "@tarojs/taro";
import {Text, View, Image} from '@tarojs/components';
import {Calendar, Cell, Space, Price} from "@nutui/nutui-react-taro"; // 1
import {IconFont} from "@nutui/icons-react-taro"; // 2

const Index2 = () => {
  return <View>Index2 Page</View>
}
export default Index2

当前项目在编译 Index1Index2 时就会出现以上错误日志;

二、解决方案

1、将示例中 1、2 两个引用的顺序保持一致即可编译成功。

2、直接修改/config/index.ts的配置:

javascript 复制代码
mini: {
      miniCssExtractPluginOption: {
        ignoreOrder: true
      }
}

加入这个配置项,直接忽略这个检查即可,推荐。

相关推荐
爱学习的程序媛42 分钟前
【Web前端】JavaScript设计模式全解析
前端·javascript·设计模式·web
小码哥_常1 小时前
从SharedPreferences到DataStore:Android存储进化之路
前端
老黑1 小时前
开源工具 AIDA:给 AI 辅助开发加一个数据采集层,让 AI 从错误中自动学习(Glama 3A 认证)
前端·react.js·ai·nodejs·cursor·vibe coding·claude code
jessecyj1 小时前
Spring boot整合quartz方法
java·前端·spring boot
苦瓜小生1 小时前
【前端】|【js手撕】经典高频面试题:手写实现function.call、apply、bind
java·前端·javascript
天若有情6732 小时前
前端HTML精讲03:页面性能优化+懒加载,搞定首屏加速
前端·性能优化·html
踩着两条虫2 小时前
AI驱动的Vue3应用开发平台深入探究(十):物料系统之内置组件库
android·前端·vue.js·人工智能·低代码·系统架构·rxjava
swipe2 小时前
AI 应用里的 Memory,不是“保存聊天记录”,而是管理上下文预算
前端·llm·agent
慧一居士2 小时前
nuxt3 项目和nuxt4 项目区别和对比
前端·vue.js
威联通安全存储3 小时前
破除“重前端、轻底层”的数字幻象:如何夯实工业数据的物理底座
前端·python