html+css 实现hover上下边框生长

news2024/11/16 18:06:00

前言:哈喽,大家好,今天给大家分享html+css 绚丽效果!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕

文章目录

  • 效果
  • 原理解析
    • 1.按钮的组成。
      • 1.1 按钮的组成
      • 1.2 此效果的关键点在于,==button:before是右(right)定位==,==button:after是左(left)定位==,这一步==相当于改变了`定位原点`==。
    • 2. 当hover时,before和after==宽度都变为100%==,button加个==文字阴影==。
    • 3.具体的变换参数,直接==看代码==,可以一键复制,查看效果
  • 上代码,可以直接复制使用
    • 目录
    • html
    • css

效果

实现hover上下边框生长效果

原理解析

1.按钮的组成。

1.1 按钮的组成

按钮的组成

1.2 此效果的关键点在于,button:before是右(right)定位button:after是左(left)定位,这一步相当于改变了定位原点

button:before是右(right)定位
button:after是左(left)定位

2. 当hover时,before和after宽度都变为100%,button加个文字阴影

/*hover时*/
/*宽度改变*/
.butUpDownBorder:hover::after {
  width: 100%;
}

.butUpDownBorder:hover::before {
  width: 100%;
}
/*文字阴影改变*/
.butUpDownBorder:hover {
  text-shadow: 0 0 10px #fff, 0 0 20px #fff, 0 0 30px #e60073,
  0 0 40px #e60073, 0 0 50px #e60073, 0 0 60px #e60073, 0 0 70px #e60073;
}

3.具体的变换参数,直接看代码,可以一键复制,查看效果

上代码,可以直接复制使用

目录

实现hover上下边框生长目录

html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>html+css 实现hover上下边框生长</title>
    <link rel="stylesheet" href="./style.css">
</head>
<body>
<div class="container">
    <h1 style="text-align: center;color:#fff;margin-bottom: 50px;padding-top: 50px; text-shadow: 0 3px 3px #4c6ed3;">
        html+css 实现hover上下边框生长</h1>

    <div class="wrapper">
        <button class="butUpDownBorder">求点赞</button>
        <button class="butUpDownBorder">求关注</button>
        <button class="butUpDownBorder">求收藏</button>
        <button class="butUpDownBorder">求转发</button>
    </div>
</div>

</body>
</html>

css

*
{
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
:root
{
  --btn-bg-color:#fff;
  --font-color-black: #000;
  --btn-bg-color-hover: #FF5833;
}
.container{
  min-height: 100vh;
  background-color: #0e1538;
}
.wrapper{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap:40px;
}

.butUpDownBorder {
  position: relative;
  padding: 6px;
  padding-bottom: 0.5em;
  padding-top: 0.5em;
  font-size: 20px;
  text-transform: uppercase;
  color: #fff;
  border: none;
  background-color: transparent;
  transition: 0.3s;
}

.butUpDownBorder::after {
  content: '';
  background-color: white;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 10%;
  height: 5%;
  transition: 0.3s;
}

.butUpDownBorder::before {
  content: '';
  background-color: white;
  position: absolute;
  top: 0;
  right: 0;
  width: 10%;
  height: 5%;
  transition: 0.3s;
}
/*hover时*/
/*宽度改变*/
.butUpDownBorder:hover::after {
  width: 100%;
}

.butUpDownBorder:hover::before {
  width: 100%;
}
/*文字阴影改变*/
.butUpDownBorder:hover {
  text-shadow: 0 0 10px #fff, 0 0 20px #fff, 0 0 30px #e60073,
  0 0 40px #e60073, 0 0 50px #e60073, 0 0 60px #e60073, 0 0 70px #e60073;
}

到此这篇文章就介绍到这了,更多精彩内容请关注本人以前的文章或继续浏览下面的文章,创作不易,如果能帮助到大家,希望大家多多支持宝码香车~💕

整理不易,点赞关注宝码香车

更多专栏订阅推荐:
👍 html+css+js 绚丽效果
💕 vue
✈️ Electron
⭐️ js
📝 字符串
✍️ 时间对象(Date())操作

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1984044.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

平安城市行业无人机解决方案(夜间作业场景应用)

夜间作业场景痛点&#xff1a; 夜间隐蔽作业需要权衡看清楚和隐蔽性 可见光相机夜间无法使用 “五合一”混合夜视传感器-H20N 夜间侦察巡逻 H20N星光级相机提升夜间作业覆盖效率 Zenmuse H20N变焦镜头夜景模式效果 Zenmuse H20N变焦镜头夜景模式效果 Zenmuse H20T变焦镜头夜…

【Android】四大组件(Activity、Service、Broadcast Receiver、Content Provider)、结构目录

文章目录 Android系统架构Android四大组件ActivityServiceBroadcast ReceiverContent Provider 两大视图主要结构目录 Android系统架构 https://blog.csdn.net/xzzteach/article/details/140904613 Android四大组件 Activity 一个 Activity 包含了用户能够看到的界面&#xff0…

判断Windows设备是否为翻新

网购设备难免踩坑&#xff0c;一定要学会查验&#xff0c;及时保存证据并投诉商家。 1、查验包装信息&#xff0c;是否有拆封痕迹 商家翻新处理的第一道工序就是换个完整的包装&#xff0c;一般不会把拆过的包装打包卖给买家&#xff0c;除非声明是二手。 2、查验序列号&#x…

干货-并发编程提高——线程的唤醒(七)

没有参数的wait()方法等价于wait(0),等价于永远等下去。虚假唤醒&#xff1a;一个线程也能在没有被通知&#xff0c;中断&#xff0c;或超时的情况下被唤醒。也即所谓的“虚假唤醒”。解决虚假唤醒的办法就是通过while循环来判断条件。 何为虚假唤醒 简单讲&#xff0c;要避免使…

磷酸铁锂与三元锂:谁会取得压倒性的胜利?

在电动车市场中&#xff0c;磷酸铁锂&#xff08;LFP&#xff09;和三元锂&#xff08;NCM/NCA&#xff09;电池是两种主要的锂离子电池技术。近年来&#xff0c;关于这两种电池的讨论愈发热烈。本文将深入探讨磷酸铁锂与三元锂的真正区别&#xff0c;以及它们在未来电动车市场…

AI8-文本检测

文本检测任务是找出图像或视频中的文字位置。不同于目标检测任务,目标检测不仅要解决定位问题,还要 解决目标分类问题。 文本在图像中的表现形式可以视为一种‘目标‘,通用的目标检测的方法也适用于文本检测,从任务本身上来 看: • 目标检测:给定图像或者视频,找出目…

什么是SQL注入?基于实例讲解

一、SQL注入的含义&#xff1a; SQL注入是一种常见的网络攻击&#xff0c;由于程序对输入数据的判断或者检验不严格&#xff0c;导致攻击者查询到了授权范围之外的数据&#xff0c;甚至还可以修改数据库中的数据&#xff0c;对数据库执行一些管理操作等&#xff0c;所以它的危…

【Material-UI】Button 中的点击事件处理(Handling clicks)详解

文章目录 一、点击事件处理基础1. 基本用法2. 事件处理器的传递 二、实际应用中的注意事项1. 事件处理逻辑的优化2. 避免过多的状态更新3. 使用合适的事件类型 三、关于文档中未提及的原生属性四、最佳实践1. 无障碍性2. 视觉反馈3. 防止重复点击 五、总结 在现代前端开发中&am…

测试TLP 使用外部 50Ω 电缆和非 50Ω 电缆影响

测试目的 实验有 SMA 母头连接器与没有SMA母头连接器 I/V 曲线的影响实验 50Ω 电缆和非 50Ω 电缆应用条件下的 I/V 曲线研究初始启动和 16A DUT(被测器件)应用条件下的脉冲电压和脉冲电流影响 开始测试前先做短路/开路校正 短路校正 开路校正 TLP取样方式与为框黄色70ns~90…

详解线程池的使用

一、线程池基础 1.1、线程池的思想 我们首先理解什么是池化技术&#xff1a; 池化技术指的是提前准备一些资源&#xff0c;在需要时可以重复使用这些预先准备的资源。 池化技术的优点主要有两个&#xff1a;提前准备和重复利用。 下面是池化技术常见的应用场景&#xff1a; …

SpringBoot+Redis 发布与订阅

两个应用都引入 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artif…

机器学习入门之无监督学习(聚类、降维(主成分分析)、关联度分析(Apriori 算法))

无监督学习是机器学习的一种类型&#xff0c;它处理没有显式标签的数据。与监督学习不同&#xff0c;无监督学习的目标是探索数据的内在结构和模式&#xff0c;而不是从标注数据中学习一个特定的映射到预定标签的函数。这使得无监督学习特别适用于探索性数据分析、找寻隐藏模式…

关于加载水印PDF、图片以及压缩包格式文件【把博客当工作记录】

写这篇文章的目的是让大家都可以学到东西,核心代码中列出了处理思维和调用方法,业务代码已经过滤掉了,希望大家不要做crud程序员!!要思考。。。该博客不懂时可联系下方。 1、流程图如下 2、策略描述 实现方式: 设计模式:父策略调动子策略 业务理念:在不影响原有业务…

【电脑基础硬件】从零开始认识主板

从零开始认识主板 一、主板及其元器件二、主板上的各个部件通信三、主板的选择 注意&#xff1a; 以下以Z790电脑主板为例进行说明。 一、主板及其元器件 IO接口&#xff1a; CPU模块 CPU是电脑的大脑&#xff0c;控制并指挥着电脑的各个模块协同工作。CPU通过主板上的插槽固定…

电路中电阻,电容和电感作用总结

电阻作用 1&#xff0c;上拉电阻 电阻的连接一般是一端接上拉的电源&#xff08;一般与芯片信号的电压值相匹配&#xff09;&#xff0c;另一端连接芯片引脚所对应的信号大概如下图 功能&#xff1a;一、预置某些引脚的功能&#xff0c;例如复位信号拉高&#xff08;失能&…

疯传!平台培养“斗士”的背后,是 AI 智能名片与 O2O 商城小程序在搞鬼

摘要&#xff1a;本文探讨了在搭建用户聚集平台以筛选和培养“斗士”的过程中&#xff0c;如何融入 AI 智能名片和 O2O 商城小程序。详细阐述了贴吧或论坛作为初始平台的优势&#xff0c;以及如何通过适当的管理和引导活动筛选出“储备斗士”。同时&#xff0c;分析了 AI 智能名…

浅谈 Mybatis 框架

文章目录 一、什么是MyBatis?1.2、JDBC 二、使用Mybatis2.1、配置MyBatis开发环境2.1.1、配置连接字符串2.1.2、配置MyBatis中的XML路径 2.2、使用MyBatis模式和语法操作数据库 三、使用 Mybatis 进行增删改查操作的要点3.1、ResultMap的用法 四、Mybatis操作难点4.1、#{ } 和…

Modbus-TCP详解

目录 Modbus-TCP Modbus TCP协议的帧结构如下&#xff1a; 实现Modbus-Tcp 使用EasyModbusTCP第三方实现Modbus-Tcp EasyModbusTCP的使用 设置IP 设置端口 设置设备地址 开启通讯 读取寄存器 写入寄存器 实例 Modbus-TCP Modbus TCP是Modbus协议的一种变体&#xff0c;它使用T…

Java多线程的单例设计模式 多种实现方法

目录 前言 饿汉式 懒汉式 Double_check volatile double_check Holder方式 枚举 前言 单例设计模式GOF23中设计模式中最常用的设计模式之一, 单例设计模式提供了多线程环境下的保证唯一实例性的解决方案, 虽然简单, 但是实现单例模式的方式多种多样, 因此需要从多个维度去…

【云原生】恰当运用kubernetes中三种探针,确保应用程序在Kubernetes集群中保持健康、可用和可靠

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…