”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何在悬停时创建边框底部的动画扩展?

如何在悬停时创建边框底部的动画扩展?

发布于2024-11-17
浏览:975

How to Create an Animated Expansion of Border Bottom on Hover?

悬停效果:边框底部的动画扩展

在这个问题中,目标是创建一个悬停效果,在悬停时扩展元素的底部边框。为了达到这种效果,我们可以利用变换属性并在悬停时将其从 0 转换为 1。

h1 {
  color: #666;
  display: inline-block;
  margin: 0;
  text-transform: uppercase;
}

h1:after {
  display: block;
  content: '';
  border-bottom: solid 3px #019fb6;
  transform: scaleX(0);
  transition: transform 250ms ease-in-out;
}

h1:hover:after {
  transform: scaleX(1);
}

此方法使用伪元素将边框过渡与文本分开,保留原始 HTML 结构。可以操作transform-origin属性来从不同方向扩展边框,如下所示:

h1.fromRight:after {
  transform-origin: 100% 50%;
}

h1.fromLeft:after {
  transform-origin: 0% 50%;
}
最新教程 更多>
  • Kotlin Null Safety 与 Java:错误喜剧(但主要是在 Java 中)
    Kotlin Null Safety 与 Java:错误喜剧(但主要是在 Java 中)
    啊,Kotlin 空安全 vs. Java!一场经典的对决,就像哥斯拉与摩斯拉一样,但摧毁城市的怪物更少,更多的是关于……好吧,无。 ? Java,保佑它的心脏,从拨号时代就已经存在了。当时,没有人担心 null 会导致您的应用程序崩溃,因为说实话,互联网导致您的应用程序崩溃的情况要普遍得多。但时...
    编程 发布于2024-11-17
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为 bool 的主要场景:语句:if、w...
    编程 发布于2024-11-17
  • 为什么我的 @font-face EOT 字体无法在 IE 7、8 和 9 中通过 HTTPS 加载?
    为什么我的 @font-face EOT 字体无法在 IE 7、8 和 9 中通过 HTTPS 加载?
    @font-face EOT 无法通过 HTTPS 加载问题排查在 IE 7,8 中通过 HTTPS 加载 @font-face EOT 字体时遇到困难,9?难题不在于 HTML 页面的 HTTPS 状态,而在于通过 HTTP 本身加载 EOT 字体。尽管收到了适当的内容类型标头,EOT 字体仍然难...
    编程 发布于2024-11-17
  • 将对象分配为 Null 实际上会影响 Java 中的垃圾收集吗?
    将对象分配为 Null 实际上会影响 Java 中的垃圾收集吗?
    在 Java 中将对象分配为 Null 对垃圾收集的影响在 Java 中将未使用的对象引用分配为 null 对垃圾收集的影响最小过程。现代 Java 垃圾收集器 (GC) 可以高效运行并迅速删除不再可达的对象,即使没有显式 null 赋值也是如此。但是,在某些例外情况下,显式 null 赋值可能会带...
    编程 发布于2024-11-17
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1和$array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求是构...
    编程 发布于2024-11-17
  • 如何在没有循环的情况下有效计算 Numpy 中一维数组的滚动标准差?
    如何在没有循环的情况下有效计算 Numpy 中一维数组的滚动标准差?
    在 Numpy 中实现一维数组的高效滚动窗口滚动窗口的概念涉及迭代数据序列并应用计算指定窗口长度内的数据子集。在给定的上下文中,任务是在不使用 Python 循环的情况下计算 Numpy 中一维数组的滚动标准差。虽然可以使用 Numpy.std 轻松获得标准差,但滚动窗口部分构成了一个挑战。然而,通...
    编程 发布于2024-11-17
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-17
  • 如何在 jQuery 中选择具有特定背景颜色的 Span?
    如何在 jQuery 中选择具有特定背景颜色的 Span?
    定位具有特定背景颜色的元素处理 div 内的跨度集合时,目标可能是隔离具有特定背景颜色的元素。虽然 [attribute=value] 选择器可能看起来很直观,但事实证明它对于根据背景颜色提取元素是无效的,因为 span 缺少该名称的属性。相反,请考虑 CSS 选择器 $('div# som...
    编程 发布于2024-11-17
  • 在 PHP 中使用绑定 SQL 变量如何提高代码安全性、性能和可维护性?
    在 PHP 中使用绑定 SQL 变量如何提高代码安全性、性能和可维护性?
    PHP 中的绑定 SQL 变量:指南尽管 SQL 字符串很流行,但您可以通过绑定变量来增强代码。这样做可以带来许多好处,包括提高安全性、性能和可维护性。在 PHP 中,绑定变量可以毫不费力地完成,使您能够编写更安全、更高效、更易读的代码。MySQL 和 PostgreSQL 绑定技术适用于 MySQ...
    编程 发布于2024-11-17
  • 如何使用 Go 的 pq 包将数据从 STDIN 导入到 PostgreSQL?
    如何使用 Go 的 pq 包将数据从 STDIN 导入到 PostgreSQL?
    如何将行从 STDIN 导入到 Postgresql? [重复]在 Go 中,您可以使用 pq 包将行从 STDIN 导入到 PostgreSQL。以下是分步解决方案:第 1 步:准备数据库连接import ( "database/sql" "githu...
    编程 发布于2024-11-17
  • 如何解决Python中类型提示的循环导入?
    如何解决Python中类型提示的循环导入?
    没有循环导入的 Python 中的类型提示在尝试将一个大类分成两个较小的类时,您会遇到循环问题进口。 “main”类导入 mixin 类,并且 mixin 类在其类型提示中引用“main”类。这会导致导入循环,导致类型提示无法正常工作。要解决此问题,可以考虑以下方法:# main.py from _...
    编程 发布于2024-11-17
  • 什么是 jQuery.fn?为什么它是 jQuery.prototype 的别名?
    什么是 jQuery.fn?为什么它是 jQuery.prototype 的别名?
    深入研究 jQuery.fn:原型的别名在 jQuery 库中,您可能会遇到神秘的 jQuery.fn。这个神秘的 fn 代表什么以及它有什么作用?Prototype 的作用在 JavaScript 领域,prototype 属性是一个至关重要的组成部分构造函数。当您使用特定构造函数创建实例时,该实...
    编程 发布于2024-11-17
  • 如何用Python实现高效的双向哈希表?
    如何用Python实现高效的双向哈希表?
    实现高效的双向哈希表双向哈希表允许键到值和值到键的查找。虽然 Python 的内置 dict 数据结构在键到值查找方面表现出色,但它并不能提供有效的值到键检索。实现双向哈希表的有效方法是利用类扩展了标准字典。此类名为 bidict,维护一个逆目录,该目录会根据对常规 dict 的任何修改自动更新。代...
    编程 发布于2024-11-17
  • PDOStatement::bindParam() 中的前导冒号真的是可选的吗?
    PDOStatement::bindParam() 中的前导冒号真的是可选的吗?
    PDOStatement::bindParam() 中参数名称的前导冒号是否真的可选?PDOStatement::bindParam() 允许您使用占位符(例如:name)在查询中指定命名参数。文档指出命名占位符的参数标识符应使用格式:name。然而,据观察,:name 和 name 似乎都可以使用...
    编程 发布于2024-11-17
  • 如何在 JavaScript 中实现稳定排序以在排序过程中保持元素顺序?
    如何在 JavaScript 中实现稳定排序以在排序过程中保持元素顺序?
    JavaScript中的稳定排序目标:基于键对对象数组进行高效排序,保持一致性和稳定性。算法推荐: 虽然存在许多排序算法,但为了满足您对稳定性的特定需求,请考虑实现非稳定排序算法,如 QuickSort 或 MergeSort。稳定排序技术:为了确保稳定性,请在排序比较函数中添加一个附加条件。具体来...
    编程 发布于2024-11-17

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3