React 与 Vue 开发差异——CSS 样式

react 中似乎与vue 不同,vue中在使用 scoped 后需要通过:deep()才能修改子组件的样式,但react 中看起来可以随意修改,不会造成样式污染吗?如何解决?

存在全局污染的情况:

情况 1:使用 createGlobalStyle

jsx 复制代码
import { createGlobalStyle } from 'styled-components'

const GlobalStyle = createGlobalStyle`
  body {
    margin: 0;
    color: red;
  }

  .ant-btn {
    border-radius: 0; /* 影响所有 antd 按钮 */
  }
`

就是显式地往全局注入 CSS。

✅ 合理用于基础 reset / normalize.css。

❌ 但不能随便在业务组件里定义,否则污染全局。

情况 2:在 styled 里写了全局选择器(嵌套 CSS)

jsx 复制代码
const Wrapper = styled.div`
  .ant-btn {
    color: red;
  }
`

这看似"写在组件里",但其实会生成类似:

css 复制代码
.sc-xxx .ant-btn { color: red }

.ant-btn 被渲染在这个组件内,就被强行覆盖了样式。

如何避免污染(最佳实践)

1️⃣ 禁止直接写全局类选择器

错误示例 ❌:

jsx 复制代码
const Box = styled.div`
  .ant-btn {
    color: red;
  }
`

正确做法 ✅:

jsx 复制代码
import { Button } from 'antd'
import styled from 'styled-components'

const StyledButton = styled(Button)`
  color: red;
`

通过"组件包裹"而非"全局类名"方式修改样式,能彻底避免污染。

2️⃣ 使用命名空间前缀统一组件风格

给每个 styled 组件统一一个命名前缀:

jsx 复制代码
const AppButton = styled.button`
  &.app-btn {
    border-radius: 4px;
  }
`

或者使用 BEM 风格

jsx 复制代码
const Wrapper = styled.div`
  &.app {
    &__header { ... }
    &__content { ... }
  }
`

这样生成的类名会被 styled-components 的哈希包裹,冲突概率几乎为零。

相关推荐
Dlrb12115 分钟前
C语言-字符串指针与函数指针
java·c语言·前端
PBitW9 分钟前
组件封装注意事项
前端·vue.js
weiggle15 分钟前
Android 输入事件分发流程:从物理触控到 Activity 的完整旅程
前端
yingyima18 分钟前
开发者必备在线工具集合 2025:实战案例解析
前端
前端毕业班20 分钟前
面试官:实现一个带类型约束的 EventEmitter
前端·面试
卷帘依旧23 分钟前
SPA 中的 Hash 和 History 模式
前端
用户44455436542626 分钟前
AndroidAutoSize使用时遇到的特麻烦bug
前端
茉莉玫瑰花茶30 分钟前
LangGraph 入门教程:构建 AI 工作流 [ 案例三 ]
前端·人工智能·python
scan72434 分钟前
pydantic格式输出
服务器·前端·javascript
ZC跨境爬虫41 分钟前
跟着MDN学HTML_day44:(ProcessingInstruction接口)
前端·javascript·ui·html·媒体