当前位置:首页 > 科技  > 软件

点击产生水波纹效果,Vue自定义指令20行代码搞定~

来源: 责编: 时间:2023-10-30 09:06:51 332观看
导读前言大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心~最近在看一些组件库的时候,发现他们有一种效果还挺好看的,就是点击会有水波效果~图片所以就想写一个 Vue 的自定义指令指

前言

大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心~Hpx28资讯网——每日最新资讯28at.com

最近在看一些组件库的时候,发现他们有一种效果还挺好看的,就是点击会有水波效果~Hpx28资讯网——每日最新资讯28at.com

图片图片Hpx28资讯网——每日最新资讯28at.com

所以就想写一个 Vue 的自定义指令指令来实现这个效果:v-rippleHpx28资讯网——每日最新资讯28at.com

使用方式是这样的:Hpx28资讯网——每日最新资讯28at.com

<Button v-ripple>我是一个按钮</Button>

实现思路

思路就是,点击了按钮某一处时,往按钮dom中插入一个圆dom,这个圆dom是相对于按钮去定位的,坐标就是(x1,y1),至于(x1,y1)要怎么去算呢?其实很简单啊Hpx28资讯网——每日最新资讯28at.com

1、先算出鼠标点击相对于按钮的坐标(x,y)Hpx28资讯网——每日最新资讯28at.com

2、(x-半径,y-半径) -> (x1,y1)Hpx28资讯网——每日最新资讯28at.com

至于(x,y)要怎么算?也很简单啊(用到getBoundingClientRect)Hpx28资讯网——每日最新资讯28at.com

1、算出鼠标点击的全局坐标Hpx28资讯网——每日最新资讯28at.com

2、算出按钮的全局坐标Hpx28资讯网——每日最新资讯28at.com

3、鼠标按钮坐标减去按钮坐标,就能得到(x,y)Hpx28资讯网——每日最新资讯28at.com

图片图片Hpx28资讯网——每日最新资讯28at.com

开始实现

首先我们准备好基础的样式Hpx28资讯网——每日最新资讯28at.com

// ripple.less#ripple {  position: absolute;  pointer-events: none;  background-color: rgb(30 184 245 / 70%);  border-radius: 50%;  transform: scale(0);  animation: ripple 600ms linear;}@keyframes ripple {  to {    opacity: 0;    transform: scale(4);  }}

接着就开始开发自定义指令了,我们要注意一件事,在插入圆dom之前,要删除圆dom,这样才能确保只有一个圆domHpx28资讯网——每日最新资讯28at.com

import './ripple.less';import type { Directive } from 'vue';export const RIPPLE_NAME = 'ripple';const createRipple = (el: HTMLElement, e: MouseEvent) => {  // 设置按钮overflow  el.style.overflow = 'hidden';  // 获取按钮的长宽  const { clientWidth, clientHeight } = el;  // 算出直径  const diameter = Math.ceil(Math.sqrt(clientWidth ** 2 + clientHeight ** 2));  // 算出半径  const radius = diameter / 2;  // 获取按钮的全局坐标  const { left, top } = el.getBoundingClientRect();  // 设置按钮的定位是relative  const position = el.style.position;  if (!position || position === 'static') {    el.style.position = 'relative';  }  // 获取鼠标点击全局坐标  const { clientX, clientY } = e;  // 创建一个圆dom  const rippleEle = document.createElement('div');  // 设置唯一标识id  rippleEle.id = RIPPLE_NAME;  // 设置长宽  rippleEle.style.width = rippleEle.style.height = `${diameter}px`;  rippleEle.style.left = `${clientX - radius - left}px`;  rippleEle.style.top = `${clientY - radius - top}px`;  // 插入圆dom  el.appendChild(rippleEle);};const removeRipple = (el: HTMLElement) => {  // 删除圆dom  const rippleEle = el.querySelector(`#${RIPPLE_NAME}`);  if (rippleEle) {    el.removeChild(rippleEle);  }};export const Ripple: Directive = {  mounted(el: HTMLElement) {    // 绑定点击事件    el.addEventListener('click', e => {      removeRipple(el);      createRipple(el, e);    });  },  unmounted(el: HTMLElement) {    // 组件卸载时记得删了    removeRipple(el);  },};

结语

我是林三心Hpx28资讯网——每日最新资讯28at.com

  • 一个待过小型toG型外包公司、大型外包公司、小公司、潜力型创业公司、大公司的作死型前端选手;
  • 一个偏前端的全干工程师;
  • 一个不正经的掘金作者;
  • 逗比的B站up主;
  • 不帅的小红书博主;
  • 喜欢打铁的篮球菜鸟;
  • 喜欢历史的乏味少年;
  • 喜欢rap的五音不全弱鸡如果你想一起学习前端,一起摸鱼,一起研究简历优化,一起研究面试进步,一起交流历史音乐篮球rap,可以来俺的摸鱼学习群哈哈,点这个,有7000多名前端小伙伴在等着一起学习哦 --> 

本文链接:http://www.28at.com/showinfo-26-15725-0.html点击产生水波纹效果,Vue自定义指令20行代码搞定~

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: .Net开发之并行计算:提升应用程序的计算能力

下一篇: 掌握Python输入输出:从键盘到文件的全面指南

标签:
  • 热门焦点
  • 消息称迪士尼要拍真人版《魔发奇缘》:女主可能也找黑人演员

    8月5日消息,迪士尼确实有点忙,忙着将不少动画改成真人版,继《美人鱼》后,真人版《白雪公主》、《魔发奇缘》也在路上了。据外媒消息称,迪士尼将打造真人版
  • 一文掌握 Golang 模糊测试(Fuzz Testing)

    模糊测试(Fuzz Testing)模糊测试(Fuzz Testing)是通过向目标系统提供非预期的输入并监视异常结果来发现软件漏洞的方法。可以用来发现应用程序、操作系统和网络协议等中的漏洞或
  • 中国家电海外掘金正当时|出海专题

    作者|吴南南编辑|胡展嘉运营|陈佳慧出品|零态LT(ID:LingTai_LT)2023年,出海市场战况空前,中国创业者在海外纷纷摩拳擦掌,以期能够把中国的商业模式、创业理念、战略打法输出海外,他们依
  • “又被陈思诚骗了”

    作者|张思齐 出品|众面(ID:ZhongMian_ZM)如今的国产悬疑电影,成了陈思诚的天下。最近大爆电影《消失的她》票房突破30亿断层夺魁暑期档,陈思诚再度风头无两。你可以说陈思诚的
  • 小米MIX Fold 3下月亮相:今年唯一无短板的全能折叠屏

    这段时间以来,包括三星、一加、荣耀等等有不少品牌旗下的最新折叠屏旗舰都有新的进展,其中荣耀、三星都已陆续发布了最新的折叠屏旗舰,尤其号荣耀Magi
  • 华为HarmonyOS 4升级计划公布:首批34款机型今日开启公测

    8月4日消息,今天下午华为正式发布了HarmonyOS 4系统,在更流畅的前提下,还带来了不少新功能,UI设计也有变化,会让手机焕然一新。华为宣布,首批机型将会在
  • 华为Mate60标准版细节曝光:经典星环相机模组回归

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
  • 2纳米决战2025

    集微网报道 从三强争霸到四雄逐鹿,2nm的厮杀声已然隐约传来。无论是老牌劲旅台积电、三星,还是誓言重回先进制程领先地位的英特尔,甚至初成立不久的新
  • iQOO Neo8 Pro真机谍照曝光:天玑9200+和V1+旗舰双芯加持

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
Top