原文地址: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. STM32 printf函数

    /******************** (C) COPYRIGHT 2012 WildFire Team *************************** * 文件名 :usart1.c * ...

  2. 纯css3实现文字间歇滚动效果

    场景: 假设有4条数据或者标题,视口中只显示两条,采用每次向上滚动一条数据来展示所有的数据.效果如图: 用JavaScript也很容易实现,但是需要操作DOM,可以参考这篇博客.考虑到项目中经常使用V ...

  3. 黄聪:is_file和file_exists效率比较

    目前在弄文件缓存的时候用到了判定文件存在与否,is_file()还是file_exists()呢?is_file和file_exists两者效率比较起来,谁的运行速度更快呢?还是做个测试吧: 1 2 ...

  4. googletest--Test Fixture

    前面博客中我们在单元测试之前会做一些变量初始化等工作,而同一个testcase的不同test之间往往会有一些初始化工作是相同的.我们不想做多余的重复的工作,当然同时也不想设置全局变量. 这个时候我们可 ...

  5. 【SpringBoot】支持Java1.6

    开发环境 Java 1.6; 需要修改的配置 指定java和tomcat版本 <!-- TO Support JDK 1.6 start --> <java.version>1 ...

  6. DB2 Rename SQL0108N错误

    今天DB2 Rename的时候遇到了“SQL0108N ‘表名’名称的限定符数是错误的. 语句如下: db2 rename tableA to tableB 异常: SQL0108N The name ...

  7. K近邻(K Nearest Neighbor-KNN)原理讲解及实现

    算法原理 K最近邻(k-Nearest Neighbor)算法是比较简单的机器学习算法.它采用测量不同特征值之间的距离方法进行分类.它的思想很简单:如果一个样本在特征空间中的k个最近邻(最相似)的样本 ...

  8. CentOS搭建SVN服务器,并通过Apache HTTP方式访问

    摘要:本文主要讲述了在centos 6.5环境下搭建svn服务器,可通过svn:\\IP方式访问.同时由于部分公司内网端口限制,并不能访问外网的svn服务器,所以特地结合了apache服务器,使得可以 ...

  9. Socket的长连接和短连接

    讨论Socket必讨论长连接和短连接 一.长连接和短连接的概念 1.长连接与短连接的概念:前者是整个通讯过程,客户端和服务端只用一个Socket对象,长期保持Socket的连接:后者是每次请求,都新建 ...

  10. T-SQL 视图

    use StudentManager go --判断视图是否存在 if exists(select * from sysobjects where name='view_ScoreQuery') dr ...