css | class中 ‘.‘ 和 ‘:‘ 的使用 | 如,何时用 &.is-selected{ ... } 何时用 &:hover{...}?

省流总结:交互时的短暂视觉反馈 → 用 :hover**,状态需要记录或切换 → 用类名如** .is-selected

🧠 本质区别:

写法 触发方式 用途
&.is-selected 依赖 class 切换 需要 JavaScript 控制状态,如选中、激活
&:hover 鼠标悬停自动触发 一般用于交互反馈,比如按钮悬停变色

问题:为何有时候使用 &.is-selected{ color:var(xxx); font-weight: 700; } 有时候使用**&:hover{** background-color:var(xxx); }

解决:

&.is-xxxx是 用于状态类的显式控制(如点击后加类名)------》持久状态------》需要 js/class 控制状态

&:hover{ ... } 用于交互状态控制(鼠标悬停、点击等)------》自动发生临时状态------》交互反馈

CSS 预处理器(如 SCSS、Less)中的嵌套写法选择器的语义区别

我们来详细解释:


详解

🔹 &.is-selected { ... } 是什么?

这是写在一个组件的样式中,意思是:

当前元素拥有 is-selected 这个类名时,应用对应样式。

bash 复制代码
.vk-select__menu-item {
  color: #333;

  &.is-selected {
    color: var(--primary);
    font-weight: 700;
  }
}

它会编译成:

bash 复制代码
.vk-select__menu-item.is-selected {
  color: var(--primary);
  font-weight: 700;
}

✔️ 用于"状态类"的显式控制(比如点击后加类名)


🔸 &:hover { ... } 是什么?

这是用于伪类选择器,表示当前元素被鼠标悬停时

bash 复制代码
.vk-select__menu-item {
  &:hover {
    background-color: var(--hover-bg);
  }
}

它会编译成:

bash 复制代码
.vk-select__menu-item:hover {
  background-color: var(--hover-bg);
}

✔️ 用于交互状态控制(鼠标悬浮、点击等)


🎯 应用场景对比举例:

1. 下拉选项组件:

bash 复制代码
.vk-select__menu-item {
  &:hover {
    background-color: #f0f0f0; // 鼠标悬停反馈
  }

  &.is-selected {
    color: var(--primary-color);  // 被选中项加颜色高亮
    font-weight: bold;
  }
}
  • :hover 用于交互反馈,自动发生

  • .is-selected 用于记录状态持久性,比如用户点了某一项


✅ 总结记忆口诀:

:hover 是临时状态
.is-selected 是持久状态(通过 JS/class 控制)

两者经常配合使用:先 hover 提示,点击后选中变样式。

相关推荐
weixin_427771611 小时前
css font-size 的妙用
前端·css
凤凰战士芭比Q2 小时前
web中间件——Nginx
前端·nginx·中间件
一 乐2 小时前
点餐|智能点餐系统|基于java+ Springboot的动端的点餐系统小程序(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·小程序·论文
bitbitDown3 小时前
从零打造一个 Vite 脚手架工具:比你想象的简单多了
前端·javascript·面试
liangshanbo12153 小时前
CSS 数学函数完全指南:从基础计算到高级动画
前端·css
码上成长5 小时前
GraphQL:让前端自己决定要什么数据
前端·后端·graphql
冴羽5 小时前
为什么在 JavaScript 中 NaN !== NaN?背后藏着 40 年的技术故事
前端·javascript·node.js
久爱@勿忘5 小时前
vue下载项目内静态文件
前端·javascript·vue.js
前端炒粉5 小时前
21.搜索二维矩阵 II
前端·javascript·算法·矩阵
合作小小程序员小小店5 小时前
web网页开发,在线%台球俱乐部管理%系统,基于Idea,html,css,jQuery,jsp,java,ssm,mysql。
java·前端·jdk·intellij-idea·jquery·web