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

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

问题缘起

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

问题分析

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

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;
}

呈现效果会有什么不同?

相关推荐
anyup2 分钟前
🔥牛逼!3分钟生成 5 套主题,还能一键切换暗黑模式!
前端·前端框架·uni-app
进击的明明2 分钟前
深入讨论前端开发中的跨域问题🤔
前端
正在走向自律5 分钟前
企业微信消息推送全链路实战:Java后端与Vue前端集成指南
前端·vue.js·企业微信·企业微信消息推送·官方企业微信
_一两风6 分钟前
《从一道“诡异”输出题,彻底搞懂 JavaScript 的作用域与执行上下文》
前端·ecmascript 6
lcc1879 分钟前
Vue3 CompositionAPI的优势
前端·vue.js
五号厂房14 分钟前
聊一聊前端下载文件N种方式
前端
code_Bo18 分钟前
使用micro-app 多层嵌套的问题
前端·javascript·架构
小灰18 分钟前
VS Code 插件 Webview 热更新配置
前端·javascript
进击的明明23 分钟前
前端监控与前端兜底:那些我们平常没注意,但真正决定用户体验的“小机关”
前端·面试
前端老宋Running24 分钟前
我只改了个头像,为什么整个后台系统都闪了一下?
前端·react.js·面试