view-transitions实现卡片添加删除动画过渡效果代码
代码语言:html
所属分类:布局界面
代码描述: view-transitions实现卡片添加删除动画过渡效果代码
代码标签: view-transitions 卡片 添加 删除 动画 过渡
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<style>
@layer view-transitions {
/* Don’t capture the root, allowing pointer interaction while cards are animating */
@layer no-root {
:root {
view-transition-name: none;
}
::view-transition {
pointer-events: none;
}
}
/* Cards, in general, should use a bounce effect when moving to their new position */
@layer reorder-cards {
@supports (view-transition-class: card) {
.warning {
display: none;
}
:root {
--bounce-easing: linear(
0, 0.004, 0.016, 0.035, 0.063, 0.098, 0.141 13.6%, 0.25, 0.391, 0.563, 0.765,
1, 0.891 40.9%, 0.848, 0.813, 0.785, 0.766, 0.754, 0.75, 0.754, 0.766, 0.785,
0.813, 0.848, 0.891 68.2%, 1 72.7%, 0.973, 0.953, 0.941, 0.938, 0.941, 0.953,
0.973, 1, 0.988, 0.984, 0.988, 1
);
}
.card {
view-transition-class: card;
}
/* Without view-transition-class you had to write a selector that targets all cards … and that selector needed updating whenever you added/removed a card */
::view-transition-group(*.card) {
animation-timing-function: var(--bounce-easing);
animation-duration: 0.5s;
}
}
}
/* Newly added cards should animate-in */
@layer add-card {
@keyframes animate-in {
0% {
opacity: 0;
translate: 0 -200px;
}
100% {
opacity: 1;
translate: 0 0;
}
}
.........完整代码请登录后点击上方下载按钮下载查看
















网友评论0