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

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

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

前言

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

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

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

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

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

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

实现思路

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

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

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

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

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

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

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

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

开始实现

首先我们准备好基础的样式sHY28资讯网——每日最新资讯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,这样才能确保只有一个圆domsHY28资讯网——每日最新资讯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);  },};

结语

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

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

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

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

上一篇: 为什么 IT 项目仍然失败

下一篇: Envoy 基础入门教程,看这一篇就够了

标签:
  • 热门焦点
  • 帅气纯真少年!日本最帅初中生选美冠军出炉

    日本第一帅哥初一生选美大赛冠军现已正式出炉,冠军是来自千叶县的宗田悠良。日本一直热衷于各种选美大赛,从&ldquo;最美JK&rdquo;起到&ldquo;最美女星&r
  • 线程通讯的三种方法!通俗易懂

    线程通信是指多个线程之间通过某种机制进行协调和交互,例如,线程等待和通知机制就是线程通讯的主要手段之一。 在 Java 中,线程等待和通知的实现手段有以下几种方式:Object 类下
  • Automa-通过连接块来自动化你的浏览器

    1、前言通过浏览器插件可实现自动化脚本的录制与编写,具有代表性的工具就是:Selenium IDE、Katalon Recorder,对于简单的业务来说可快速实现自动化的上手工作。Selenium IDEKat
  • 多线程开发带来的问题与解决方法

    使用多线程主要会带来以下几个问题:(一)线程安全问题  线程安全问题指的是在某一线程从开始访问到结束访问某一数据期间,该数据被其他的线程所修改,那么对于当前线程而言,该线程
  • 19个 JavaScript 单行代码技巧,让你看起来像个专业人士

    今天这篇文章跟大家分享18个JS单行代码,你只需花几分钟时间,即可帮助您了解一些您可能不知道的 JS 知识,如果您已经知道了,就当作复习一下,古人云,温故而知新嘛。现在,我们就开始今
  • 一篇文章带你了解 CSS 属性选择器

    属性选择器对带有指定属性的 HTML 元素设置样式。可以为拥有指定属性的 HTML 元素设置样式,而不仅限于 class 和 id 属性。一、了解属性选择器CSS属性选择器提供了一种简单而
  • Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein&ldquo;利用市场支配力量强迫服装厂商与之签订独家
  • 华为和江淮汽车合作开发百万元问界MPV?双方回应来了

    8月1日消息,郭明錤今天在社交平台发文称,华为正在和江淮汽车合作,开发售价在100万元的问界MPV,预计在2024年第2季度量产,销量目标为上市首年交付5万辆。
  • 最薄的14英寸游戏笔记本电脑 Alienware X14已可以购买

    2022年1月份在国际消费电子展(CES2022)上首次亮相的Alienware新品——Alienware X14现在已经可以购买了,这款笔记本电脑被誉为世界上最薄的 14 英寸游戏笔
Top