运用directives在vue组件中添加ripple动画效果
技术
1 分钟阅读
实际效果
什么是 directives?
vue 官方文档对 directives 定义是“自定义指令,用来对 DOM 元素进行底层操作”。
简单来说,因为 MVVM 模式是数据驱动的,所以不提倡直接操作 DOM。但偶尔会遇到多个场景必须操作 DOM,且逻辑基本一致的情况,此时使用 directives 可以抽象逻辑、提高复用。
v-show
就是一个典型的 directives。本质上v-show
只是改变 DOM 的 CSS{ display: none }
,仅此而已。
如何做到 ripple 效果?
1. 确定点击/触摸位置
const posX = e.pageX - e.currentTarget.offsetLeft
const posY = e.pageY - e.currentTarget.offsetTop
2. 绝对定位添加 ripple 层
let spanEl = document.createElement('span');
spanEl.className = 'ripple';
e.currentTarget.appendChild(spanEl);
3. 添加CSS 圆形扩散效果
.ripple {
background: rgba(255, 255, 255, 0.4);
border-radius: 50%;
height: 0;
opacity: 1;
position: absolute;
transform: scale(0);
width: 0;
}
.ripple-effect {
animation: ripple-drop .6s linear;
}
@keyframes ripple-drop {
100% {
transform: scale(2);
opacity: 0;
}
}
DEMO
思考:不使用 directives 实现的缺点
-
需要 ripple 和 non-ripple 两种组件,代码冗余提高,且不够灵活
-
在生命周期中执行逻辑没有 directives 钩子函数清晰
帮我买杯咖啡吧 ☕️
微信打赏
长按手机屏幕
以太坊地址: 0xB029143abE1Cb60a69A8e4670Ed26949aE213Bc5