原文地址:https://segmentfault.com/a/1190000015089396

拓展地址:https://scrimba.com/c/cWqNNnC2

HTML code:

<nav>
<ul>
<li>Home</li>
</ul>
</nav>

CSS code:

/* 子元素垂直、水平居中 */
body {
margin:;
padding:;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
background-color: black;
}
:root {
--time-slot-length: 0.1s;
--t1x: var(--time-slot-length);
--t2x: calc(var(--time-slot-length) * 2);
--t3x: calc(var(--time-slot-length) * 3);
--t4x: calc(var(--time-slot-length) * 4);
--color: dodgerblue;
}
nav ul {
padding:;
}
nav ul li {
color: white;
list-style-type: none;
font-family: sans-serif;
text-transform: uppercase;
width: 8em;
height: 3em;
border: 1px solid rgba(255, 255, 255, 0.2);
border-radius: 0.1em;
text-align: center;
line-height: 3em;
letter-spacing: 0.1em;
position: relative;
transition: var(--t4x); /* duration 4x */
margin: 1em;
} nav ul li:hover {
color: var(--color);
/* 在描边结束后,在按钮四周增加一个脉冲动画,加强动感 */
animation: pulse ease-out 1s var(--t4x); /* delay 4x */
}
/* 用 before 伪元素定义上边框和右边框,其中边框颜色因会多次被用到,所以采用变量:
类似地,用 after 伪元素定义右边框和下边框 */
nav ul li::before,
nav ul li::after {
content: '';
position: absolute;;
width:;
height:;
border-radius: 0.1em;
visibility: hidden;
} nav ul li::before {
top:;
left:;
border-top: 1px solid var(--color);
border-right: 1px solid var(--color);
transition:
/* 属性 速度曲线 所花时间 开始时间 */
height linear var(--t1x) var(--t2x), /* delay 2x */
width linear var(--t1x) var(--t3x), /* delay 3x */
visibility 0s var(--t4x); /* delay 4x */
} nav ul li::after {
bottom:;
right:;
border-bottom: 1px solid var(--color);
border-left: 1px solid var(--color);
transition:
height linear var(--t1x),
width linear var(--t1x) var(--t1x), /* delay 1x */
visibility 0s var(--t2x); /* delay 2x */
} nav ul li:hover::before,
nav ul li:hover::after {
width: 100%;
height: 100%;
visibility: visible;
} nav ul li:hover::before {
transition:
visibility 0s,
width linear var(--t1x),
height linear var(--t1x) var(--t1x); /* delay 1x */
} nav ul li:hover::after {
transition:
visibility 0s var(--t2x), /* delay 2x */
width linear var(--t1x) var(--t2x), /* delay 2x */
height linear var(--t1x) var(--t3x); /* delay 3x */
} @keyframes pulse {
from {
/* rgb(30, 144, 255) = dodgerblue */
box-shadow: 0 0 rgba(30, 144, 255, 0.5);
} to {
box-shadow: 0 0 0 1em rgba(30, 144, 255, 0);
}
}

37.如何把握好 transition 和 animation 的时序,创作描边按钮特效的更多相关文章

  1. 前端每日实战:37# 视频演示如何把握好 transition 和 animation 的时序,创作描边按钮特效

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/mKdzZM 可交互视频教程 此视频 ...

  2. 如何把握好 transition 和 animation 的时序,创作描边按钮特效

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/mKdzZM 可交互视频教 ...

  3. 终于不再对transition和animation,傻傻分不清楚了 --vue中使用transition和animation

    以前写页面注重在功能上,对于transition和animation是只闻其声,不见其人,对于页面动画效果心理一直痒痒的.最近做活动页面,要求页面比较酷炫,终于有机会认真了解了. transition ...

  4. 弄清 CSS3 的 transition 和 animation

    弄清 CSS3 的 transition 和 animation transition transition 属性是 transition-property, transition-duration, ...

  5. css3实践之图片轮播(Transform,Transition和Animation)

    楼主喜欢追求视觉上的享受,虽常以牺牲性能无法兼容为代价却也乐此不疲.本文就通过一个个的demo演示来简单了解下css3下的Transform,Transition和Animation. 本文需要实现效 ...

  6. css010 css的transform transition和animation

    css010 css的transform transition和animation 看着没有一个能想起他们是干什么的.. 1.         Transform    Transform(变形) r ...

  7. transition和animation动画简介

    本文介绍CSS动画的两大组成部分:transition和animation.我不打算给出每一条属性的详尽介绍,那样可以写一本书.这篇文章只是一个简介,帮助初学者了解全貌,同时又是一个快速指南,当你想不 ...

  8. CSS3中动画属性transform、transition 和 animation

    CSS3中和动画有关的属性有三个 transform.transition 和 animation.下面来一一说明:        transform   从字面来看transform的释义为改变,使 ...

  9. transition与animation

    以前,一直都知道,transition是animation的一个简化版,甚至不算是动画,而是一种过渡. transition的用法 早两天用transition写了一个按钮滑动的效果,类似于IOS的设 ...

随机推荐

  1. MySQL Binlog解析

    https://yq.aliyun.com/articles/238364?spm=5176.8067842.tagmain.52.73PjU3 摘要: 概述 MySQL的安装可以参考:Linux(C ...

  2. Windows核心编程 中部分代码 Delphi 实现

    // ① Delphi 使用 Interlocked 系列函数 var MyValue:Longint = ; // = Integer begin InterlockedIncrement(MyVa ...

  3. windows server core 远程桌面

    要允许其它计算机透过远程桌面登入Server Core主机,我们需要先调整注册机码,并开启对应的防火墙端口号首先,我们开启登录编辑程序(regedit.exe),找到HKEY_LOCAL_MACHIN ...

  4. 恢复word中审阅选项卡

    碰到在Word中,使用自定义功能区添加审阅选项卡,仍然不显示审阅选项卡 二个办法: 1.检查COM加载项,找出并从此禁用,如:iWebOffice2009.ocx 2.创建自定选项卡“审阅(自定义)” ...

  5. 安装node.msi 格式的文件失败

    in10 安装node.msi格式的文件,出现2503 2502 错误码, win+x 打开 在命令提示符窗口中输入: msiexec /package "安装msi格式的文件的全路径&qu ...

  6. Elasticsearch Internals: Networking Introduction An Overview of the Network Topology

    This article introduces the networking part of Elasticsearch. We look at the network topology of an ...

  7. 【Graphite】使用dropwizard.metrics向Graphite中写入指标项数据

    graphite 定时向Graphite中写入指标项数据,指标项模拟个数3000个 使用的类库 官方文档   dropwizard的github地址 Metric官方文档 metrics.dropwi ...

  8. if的各种真假判断

  9. Razor语法记录

    虽然现在用着ASP.NET MVC但是cshtml使用Razor的标准形式去布局用的还是很少,这里就一点点把用到的关键点慢慢记下来,方便自己日后回忆吧! 1.将Action中返回的html字符串转换为 ...

  10. PAT 乙级 1046 划拳(15) C++版

    1046. 划拳(15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 划拳是古老中国酒文化的一个有趣的组成部分 ...