前端设计中如何在鼠标悬浮时同步修改块内样式

虽然只是一个小问题,但这个解决问题的过程也深化了自己对盒子模型的理解

问题缘起

正在写一个登录注册的小窗口,想要在鼠标悬浮阶段让按钮和文字都变色,但是发现实操的时候按钮和文字没办法同时变色
鼠标悬停前 鼠标悬停后

问题分析

仔细分析了下该模板的代码块:

html 复制代码
 <a href="#" class="btn-main" @click.prevent="onSubmit">
    <span></span>
    <span></span>
    <span></span>
    <span></span>
    <strong>登录</strong>
</a>
<a href="#" class="btn-main">
    <span></span>
    <span></span>
    <span></span>
    <span></span>
    <strong>注册</strong>
</a>

然后再查看样式代码:

css 复制代码
.btn-main {
    position: relative;
    display: inline-block;
    padding: 10px 20px;
    color: #fff !important;
    background-color: #000;
    font-size: 16px;
    text-decoration: none;
    text-transform: uppercase;
    background: transparent;
    border: none;
    overflow: hidden;
    transition: background 0.3s, color 0.3s;
    font-family: "SimSun";
    letter-spacing: 4px;
    border-radius: 5px;
}
.btn-main strong {
  color: #fff !important;
}//解决和main.css的样式冲突
.btn-main:hover {
    background: #fff;
    color: #212931;
}

可以看到,在鼠标悬浮到时候,只是改变了<a>的样式,并没有改变其中子块<strong></strong>的样式:

问题解决

需要在hover的同时同步修改strong子块的样式,可以增加代码如下:

css 复制代码
.btn-main:hover strong {
  color: #212931 !important;
}

问题得到解决:悬浮后能同步修改块内颜色

debug思路总结

  1. 通过网页开发者工具,获得某个块的线索(比如颜色可能为#212931)
  2. 根据线索,明确嵌套结构以及可能存在冲突的css文件
  3. 对与css冲突,可以用!important提高优先级
  4. 对于找到的块,使用hover+块类别的形式解决

进一步思考

如果作以下修改:

css 复制代码
.btn-main strong:hover{
  color: #212931 !important;
}

呈现效果会有什么不同?

相关推荐
css趣多多7 小时前
ctx 上下文对象控制新增 / 编辑表单显示隐藏的逻辑
前端
_codemonster7 小时前
Vue的三种使用方式对比
前端·javascript·vue.js
寻找奶酪的mouse7 小时前
30岁技术人对职业和生活的思考
前端·后端·年终总结
梦想很大很大7 小时前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go
We་ct7 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
张3蜂7 小时前
深入理解 Python 的 frozenset:为什么要有“不可变集合”?
前端·python·spring
无小道7 小时前
Qt——事件简单介绍
开发语言·前端·qt
广州华水科技8 小时前
GNSS与单北斗变形监测技术的应用现状分析与未来发展方向
前端
code_YuJun8 小时前
corepack 作用
前端
千寻girling8 小时前
Koa.js 教程 | 一份不可多得的 Node.js 的 Web 框架 Koa.js 教程
前端·后端·面试