日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

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

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

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

前言

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

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

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

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

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

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

實現思路

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

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

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

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

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

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

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

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

開始實現

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

結語

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

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

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

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

上一篇: 為什么 IT 項目仍然失敗

下一篇: Envoy 基礎入門教程,看這一篇就夠了

標簽:
  • 熱門焦點
  • CSS單標簽實現轉轉logo

    轉轉品牌升級后更新了全新的Logo,今天我們用純CSS來實現轉轉的新Logo,為了有一定的挑戰性,這里我們只使用一個標簽實現,將最大化的使用CSS能力完成Logo的繪制與動畫效果。新logo
  • 零售大模型“干中學”,攀爬數字化珠峰

    文/侯煜編輯/cc來源/華爾街科技眼對于絕大多數登山愛好者而言,攀爬珠穆朗瑪峰可謂終極目標。攀登珠峰的商業路線有兩條,一是尼泊爾境內的南坡路線,一是中國境內的北坡路線。相
  • 破圈是B站頭上的緊箍咒

    來源 | 光子星球撰文 | 吳坤諺編輯 | 吳先之每年的暑期檔都少不了瞄準追劇女孩們的古偶劇集,2021年有優酷的《山河令》,2022年有愛奇藝的《蒼蘭訣》,今年卻輪到小破站抓住了追
  • ESG的面子與里子

    來源 | 光子星球撰文 | 吳坤諺編輯 | 吳先之三伏大幕拉起,各地高溫預警不絕,但處于厄爾尼諾大&ldquo;烤&rdquo;之下的除了眾生,還有各大企業發布的ESG報告。ESG是&ldquo;環境保
  • iQOO 11S評測:行業唯一的200W標準版旗艦

    【Techweb評測】去年底,iQOO推出了“電競旗艦”iQOO 11系列,作為一款性能強機,該機不僅全球首發2K 144Hz E6全感屏,搭載了第二代驍龍8平臺及144Hz電競
  • 聯想的ThinkBook Plus下一版曝光,鍵盤旁邊塞個平板

    ThinkBook Plus 是聯想的一個特殊筆記本類別,它在封面放入了一塊墨水屏,也給人留下了較為深刻的印象。據有人爆料,聯想的下一款 ThinkBook Plus 可能更特殊,它
  • SN570 NVMe SSD固態硬盤 價格與性能兼具

    SN570 NVMe SSD固態硬盤是西部數據發布的最新一代WD Blue系列的固態硬盤,不僅閃存技術更為精進,性能也得到了進一步的躍升。WD Blue SN570 NVMe SSD的包裝外
  • 華為舉行春季智慧辦公新品發布會 首次推出電子墨水屏平板

    北京時間2月27日晚,華為在巴塞羅那舉行春季智慧辦公新品發布會,在海外市場推出之前已經在中國市場上市的筆記本、平板、激光打印機等辦公產品,并首次推出搭載
  • 北京:科技教育體驗基地開始登記

      北京“科技館之城”科技教育體驗基地登記和認證工作日前啟動。首批北京科技教育體驗基地擬于2023年全國科普日期間掛牌,后續還將開展常態化登記。  北京科技教育體驗基
Top 主站蜘蛛池模板: 海阳市| 时尚| 金堂县| 宁南县| 犍为县| 凭祥市| 保亭| 贡嘎县| 永修县| 明溪县| 广平县| 皮山县| 钦州市| 河西区| 深圳市| 芜湖县| 甘泉县| 广灵县| 嘉祥县| 柯坪县| 闵行区| 政和县| 伊川县| 江安县| 获嘉县| 沾化县| 北票市| 通化县| 阿巴嘎旗| 大石桥市| 军事| 五指山市| 攀枝花市| 鹿泉市| 彭水| 蕉岭县| 滦平县| 西安市| 嘉定区| 京山县| 略阳县|