成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

點擊產生水波紋效果,Vue自定義指令20行代碼搞定~

開發 前端
思路就是,點擊了按鈕某一處時,往按鈕dom中插入一個圓dom,這個圓dom是相對于按鈕去定位的,坐標就是(x1,y1),至于(x1,y1)要怎么去算呢?其實很簡單啊!

前言

大家好,我是林三心,用最通俗易懂的話講最難的知識點是我的座右銘,基礎是進階的前提是我的初心~

最近在看一些組件庫的時候,發現他們有一種效果還挺好看的,就是點擊會有水波效果~

圖片圖片

所以就想寫一個 Vue 的自定義指令指令來實現這個效果:v-ripple

使用方式是這樣的:

<Button v-ripple>我是一個按鈕</Button>

實現思路

思路就是,點擊了按鈕某一處時,往按鈕dom中插入一個圓dom,這個圓dom是相對于按鈕去定位的,坐標就是(x1,y1),至于(x1,y1)要怎么去算呢?其實很簡單啊

1、先算出鼠標點擊相對于按鈕的坐標(x,y)

2、(x-半徑,y-半徑) -> (x1,y1)

至于(x,y)要怎么算?也很簡單啊(用到getBoundingClientRect)

1、算出鼠標點擊的全局坐標

2、算出按鈕的全局坐標

3、鼠標按鈕坐標減去按鈕坐標,就能得到(x,y)

圖片圖片

開始實現

首先我們準備好基礎的樣式

// 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,這樣才能確保只有一個圓dom

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);
  },
};

結語

我是林三心

  • 一個待過小型toG型外包公司、大型外包公司、小公司、潛力型創業公司、大公司的作死型前端選手;
  • 一個偏前端的全干工程師;
  • 一個不正經的掘金作者;
  • 逗比的B站up主;
  • 不帥的小紅書博主;
  • 喜歡打鐵的籃球菜鳥;
  • 喜歡歷史的乏味少年;
  • 喜歡rap的五音不全弱雞如果你想一起學習前端,一起摸魚,一起研究簡歷優化,一起研究面試進步,一起交流歷史音樂籃球rap,可以來俺的摸魚學習群哈哈,點這個,有7000多名前端小伙伴在等著一起學習哦 --> 
責任編輯:武曉燕 來源: 前端之神
相關推薦

2021-09-14 15:13:18

鴻蒙HarmonyOS應用

2023-12-20 17:28:48

水波紋ArkUI動畫開發

2024-05-31 08:43:31

2021-09-02 10:00:42

鴻蒙HarmonyOS應用

2022-02-22 13:14:30

Vue自定義指令注冊

2021-07-05 15:35:47

Vue前端代碼

2023-06-28 08:05:46

場景vue3自定義

2021-11-30 08:19:43

Vue3 插件Vue應用

2020-12-28 10:10:04

Vue自定義指令前端

2022-01-20 07:31:49

架構

2023-07-21 19:16:59

OpenAIChatGPT

2022-07-26 01:06:18

Vue3自定義指令

2016-09-19 21:37:58

vue特效組件Web

2016-04-06 11:14:48

iOS相機自定義

2024-11-08 17:22:22

2021-02-18 08:19:21

Vue自定義Vue 3.0

2024-06-03 10:00:51

Vue 3語法插槽

2013-03-28 10:58:30

自定義Android界android

2013-01-06 10:43:54

Android開發View特效

2020-04-24 12:16:48

Python 圖像分類實戰
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美在线网站 | 91在线视频播放 | 不卡一区 | 久久久九九九九 | 羞羞午夜| 国产精品视频久久久 | 久久精品亚洲 | 国产 日韩 欧美 在线 | 2019精品手机国产品在线 | h视频免费在线观看 | 国产精品成人在线播放 | 国产电影一区 | 欧产日产国产精品视频 | 一区二区三区免费网站 | 91亚洲精品久久久电影 | 欧美精品福利视频 | 黄网站涩免费蜜桃网站 | 国产精品免费观看视频 | 日韩精品一区二区三区 | 韩日中文字幕 | 日韩视频1| 欧美精品久久久久 | 国产日韩欧美精品一区二区三区 | 午夜精品久久久久久久久久久久久 | 久久久久国产一区二区三区 | 午夜小视频在线观看 | 久久国产精品一区二区三区 | 狠狠狠色丁香婷婷综合久久五月 | 亚洲成人国产综合 | 国产精品久久久久久久久久免费看 | 成人av观看 | 精品一区二区三区在线观看国产 | 国产精品视频一区二区三区 | 四虎免费视频 | 天天操天天操 | 亚洲一级av毛片 | 九九久久精品 | 成人在线激情 | 国产亚洲成av人片在线观看桃 | 999精品视频在线观看 | 在线免费国产 |