AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當前位置:首頁 > 科技  > 軟件

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

來源: 責編: 時間:2023-10-30 09:06:51 259觀看
導讀前言大家好,我是林三心,用最通俗易懂的話講最難的知識點是我的座右銘,基礎是進階的前提是我的初心~最近在看一些組件庫的時候,發現他們有一種效果還挺好看的,就是點擊會有水波效果~圖片所以就想寫一個 Vue 的自定義指令指

前言

大家好,我是林三心,用最通俗易懂的話講最難的知識點是我的座右銘,基礎是進階的前提是我的初心~9wP28資訊網——每日最新資訊28at.com

最近在看一些組件庫的時候,發現他們有一種效果還挺好看的,就是點擊會有水波效果~9wP28資訊網——每日最新資訊28at.com

圖片圖片9wP28資訊網——每日最新資訊28at.com

所以就想寫一個 Vue 的自定義指令指令來實現這個效果:v-ripple9wP28資訊網——每日最新資訊28at.com

使用方式是這樣的:9wP28資訊網——每日最新資訊28at.com

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

實現思路

思路就是,點擊了按鈕某一處時,往按鈕dom中插入一個圓dom,這個圓dom是相對于按鈕去定位的,坐標就是(x1,y1),至于(x1,y1)要怎么去算呢?其實很簡單啊9wP28資訊網——每日最新資訊28at.com

1、先算出鼠標點擊相對于按鈕的坐標(x,y)9wP28資訊網——每日最新資訊28at.com

2、(x-半徑,y-半徑) -> (x1,y1)9wP28資訊網——每日最新資訊28at.com

至于(x,y)要怎么算?也很簡單啊(用到getBoundingClientRect)9wP28資訊網——每日最新資訊28at.com

1、算出鼠標點擊的全局坐標9wP28資訊網——每日最新資訊28at.com

2、算出按鈕的全局坐標9wP28資訊網——每日最新資訊28at.com

3、鼠標按鈕坐標減去按鈕坐標,就能得到(x,y)9wP28資訊網——每日最新資訊28at.com

圖片圖片9wP28資訊網——每日最新資訊28at.com

開始實現

首先我們準備好基礎的樣式9wP28資訊網——每日最新資訊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,這樣才能確保只有一個圓dom9wP28資訊網——每日最新資訊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);  },};

結語

我是林三心9wP28資訊網——每日最新資訊28at.com

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

本文鏈接:http://www.tebozhan.com/showinfo-26-15725-0.html點擊產生水波紋效果,Vue自定義指令20行代碼搞定~

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: .Net開發之并行計算:提升應用程序的計算能力

下一篇: 掌握Python輸入輸出:從鍵盤到文件的全面指南

標簽:
  • 熱門焦點
  • Mate60手機殼曝光 致敬自己的經典設計

    8月3日消息,今天下午博主數碼閑聊站帶來了華為Mate60的第三方手機殼圖,可以讓我們在真機發布之前看看這款華為全新旗艦的大致輪廓。從曝光的圖片看,Mate 60背后攝像頭面積依然
  • 小米官宣:2023年上半年出貨量中國第一!

    今日早間,小米電視官方微博帶來消息,稱2023年小米電視上半年出貨量達到了中國第一,同時還表示小米電視的巨屏風暴即將開始。“公布一個好消息2023年#小米電視上半年出貨量中國
  • 小米降噪藍牙耳機Necklace分享:聽一首歌 讀懂一個故事

    在今天下午的小米Civi 2新品發布會上,小米還帶來了一款新的降噪藍牙耳機Necklace,我們也在發布結束的第一時間給大家帶來這款耳機的簡單分享。現在大家能見到最多的藍牙耳機
  • Rust中的高吞吐量流處理

    作者 | Noz編譯 | 王瑞平本篇文章主要介紹了Rust中流處理的概念、方法和優化。作者不僅介紹了流處理的基本概念以及Rust中常用的流處理庫,還使用這些庫實現了一個流處理程序
  • K8S | Service服務發現

    一、背景在微服務架構中,這里以開發環境「Dev」為基礎來描述,在K8S集群中通常會開放:路由網關、注冊中心、配置中心等相關服務,可以被集群外部訪問;圖片對于測試「Tes」環境或者
  • 一個注解實現接口冪等,這樣才優雅!

    場景碼猿慢病云管理系統中其實高并發的場景不是很多,沒有必要每個接口都去考慮并發高的場景,比如添加住院患者的這個接口,具體的業務代碼就不貼了,業務偽代碼如下:圖片上述代碼有
  • 共享單車的故事講到哪了?

    來源丨海克財經與共享充電寶相差不多,共享單車已很久沒有被國內熱點新聞關照到了。除了一再漲價和用戶直呼用不起了。近日多家媒體再發報道稱,成都、天津、鄭州等地多個共享單
  • 阿里大調整

    來源:產品劉有媒體報道稱,近期淘寶天貓集團啟動了近年來最大的人力制度改革,涉及員工績效、層級體系等多個核心事項,目前已形成一個初步的&ldquo;征求意見版&rdquo;:1、取消P序列
  • 華為Mate 60保護殼曝光:碩大后置相機模組 凸起程度有驚喜

    這段時間以來,關于華為新旗艦的爆料日漸密集。據此前多方爆料,今年華為將開始恢復一年雙旗艦戰略,除上半年推出的P60系列外,往年下半年的Mate系列也將
Top