解决@ant-design/icons导致的样式异常

在使用antd+tailwind时 通常会使用layer模式

js 复制代码
    <StyleProvider layer>
      <ConfigProvider locale={zhCN}>
        <App className='w-full h-full relative m-0 p-0'>
          {useRoutes(router)}
        </App>
      </ConfigProvider>
    </StyleProvider>
css 复制代码
@layer theme, base, antd, components, utilities;
@import 'tailwindcss';

此时layer的顺序会非常重要 决定了样式的覆盖情况

但是某些情况下 icons会造成layer顺序异常

原因在于 一开始 icon组件没有接收到StyleProvider注入的layer 它会在<head>顶部插入样式

html 复制代码
<style data-rc-order="prepend" rc-util-key="@ant-design-icons">
.anticon{
xxx

一般情况下 如果有icon接受到layer 会注入@layer antd开头的样式 并插入<head>末尾 ;但是在已经存在head>style[rc-util-key="@ant-design-icons"]的情况下 会复用这个节点 只修改其内容

因此 这个style会被改为

html 复制代码
<style data-rc-order="prepend" rc-util-key="@ant-design-icons">
@layer antd {xxx

它是<head>的第一个元素 让@layer antd的定义比其他layer更早 使其优先级降低

解决方法

  • 使用@ant-design/icons^5 使其与antd版本匹配 参考文档
  • 不要 从antd导入message等函数式组件 而是使用App.useApp
  • 如果你的项目和我一样 在axios的拦截器里用了message 也没关系 可以这样做
js 复制代码
    <StyleProvider layer>
      <ConfigProvider locale={zhCN}>
        <App className='w-full h-full relative m-0 p-0'>
          {useRoutes(router)}
          <RightOutlined className='hidden' />
        </App>
      </ConfigProvider>
    </StyleProvider>

提前把可能引发错误的style节点固定在head末尾

相关推荐
zzywxc78718 分钟前
PyTorch分布式训练:从入门到精通
前端·javascript·人工智能·深度学习·react.js·技术栈深潜计划
懋学的前端攻城狮1 小时前
Next.js + TypeScript + Shadcn UI 实战:构建可折叠侧边栏与动态内容加载
前端·react.js·next.js
止观止12 小时前
Remix框架:高性能React全栈开发实战
前端·react.js·前端框架·remix
安心不心安12 小时前
React ahooks——副作用类hooks之useThrottleFn
前端·javascript·react.js
今禾14 小时前
Zustand状态管理(上):现代React应用的轻量级状态解决方案
前端·react.js·前端框架
今禾15 小时前
Zustand状态管理(下):从基础到高级应用
前端·react.js·前端框架
码间舞16 小时前
什么是Tearing?为什么React的并发渲染可能会有Tearing?
前端·react.js
Moment19 小时前
推了这么久的 Turbopack,现在终于能用了 🤔🤔🤔
前端·javascript·react.js
CF14年老兵1 天前
🚀 React 面试 20 题精选:基础 + 实战 + 代码解析
前端·react.js·redux
plusone1 天前
【React18源码解析】(三)调度
react.js·前端框架·源码