vue3通過render函數實現一個菜單下拉框

背景說明

鼠標移動到產品服務上時,出現標紅的下拉框。

使用純css的方案實現最簡單,但是沒什么技術含量,棄之;使用第三方組件庫,樣式定制麻煩棄之。因此,我們使用vue3直接在頁面創建一個dom作為下拉框吧。

技術方案

先寫一個下拉框組件

首先,我們先寫一個組件,用來展示下拉框內容。組件名稱起為 :Select.vue

<template><div class="select-wrap"><span>福利商城</span><span>Saas平臺</span><span>活動定制</span></div>
</template>

渲染組件

我們要將這個組件渲染在網頁上,操作應該是這樣的:

當鼠標移動到產品服務時,將下拉框組件作為一個組件實例渲染在頁面的合適位置。

vue3中,渲染一個Vonde,核心邏輯如下:

import { createVNode, h, render, VNode } from 'vue'
import component from "./component.vue"
//1、創造包裹虛擬節點的div元素
const container = document.createElement('div');
//2、創造虛擬節點
vm = createVNode(component)
//3、將虛擬節點創造成真實DOM
render (vm, container)
//4、將渲染的結果放到body下
document.body.appendChild(container.firstElementChild)  

要知道組件渲染的位置,我們必須知道父組件(也就是產品服務的dom位置),我們通過ref來獲取父組件的dom信息。

// App.vue
<div ref="select"><span class="name">產品服務</span> 
</div>
<script setup >import { ref } from "vue"const select = ref()
</script>

當鼠標移到產品服務元素上時,渲染下拉框,我們添加個函數

// App.vue
<div ref="select"><span class="name">產品服務</span> 
</div>
<script setup >
import { ref } from "vue"
import Select from "./Select.vue"
const select = ref()
function createDom(){//1、創造包裹虛擬節點的div元素const container = document.createElement('div');//2、創造虛擬節點let vm = createVNode(Select)//3、將虛擬節點創造成真實DOMrender (vm, container)//4、將渲染的結果放到body下document.body.appendChild(container.firstElementChild) 
}
</script>

然后,添加下位置判斷

function createDom(){const left = select.value.offsetLeft + "px"const width = select.value.getBoundingClientRect().left + "px"const props = {width,left,}//1、創造包裹虛擬節點的div元素const container = document.createElement('div');//2、創造虛擬節點let vm = createVNode(Select,props)//3、將虛擬節點創造成真實DOMrender (vm, container)//4、將渲染的結果放到body下document.body.appendChild(container.firstElementChild) 
}

其中,prop是傳遞給Select組件的距離參數,在組件內設置即可。

銷毀組件

銷毀組件,我們可以使用render渲染一個空對象即可

render (vm, container)

如果需要子組件來銷毀自身,我們可以使用父子傳值

<template><div class="select-wrap" @mouseleave="beforeUnload"><span>福利商城</span><span>Saas平臺</span><span>活動定制</span></div>
</template>
<script   setup>
const emit = defineEmits(['destroy'])
function beforeUnload(){emit('destroy')
}
</script>
```js父組件里,我們需要在props中添加一個onDestroy函數,注意:onDestroy是駝峰式寫法```js
function createDom(){const left = select.value.offsetLeft + "px"const width = select.value.getBoundingClientRect().left + "px"const props = {width,left,onDestroy: () => {render(null, container)},}//1、創造包裹虛擬節點的div元素const container = document.createElement('div');//2、創造虛擬節點let vm = createVNode(Select,props)//3、將虛擬節點創造成真實DOMrender (vm, container)//4、將渲染的結果放到body下document.body.appendChild(container.firstElementChild) 
}

這樣,就實現了下拉框組件

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/72047.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/72047.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/72047.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

二、重學C++—C語言核心

上一章節&#xff1a; 一、重學C—C語言基礎-CSDN博客https://blog.csdn.net/weixin_36323170/article/details/146002496?spm1001.2014.3001.5502 本章節代碼&#xff1a; cPart2 CuiQingCheng/cppstudy - 碼云 - 開源中國https://gitee.com/cuiqingcheng/cppstudy/tree/…

2-003:MySQL 三層 B+ 樹能存多少數據?

1. 計算 B 樹能存儲多少數據 參數設定 每個數據頁&#xff08;Page&#xff09;大小&#xff1a;16KB&#xff08;16384 字節&#xff09;每個索引節點存儲的子節點數量&#xff1a; 索引項大小&#xff1a; 假設 bigint&#xff08;主鍵&#xff09;占 8 字節每個索引項存儲…

幾種常見的虛擬環境工具(Virtualenv、Conda、System Interpreter、Pipenv、Poetry)的區別和特點總結

在 PyCharm 中創建虛擬環境是一個非常直接的過程&#xff0c;可以幫助你管理項目依賴&#xff0c;確保不同項目之間的依賴不會沖突。 通過 PyCharm 創建虛擬環境 打開 PyCharm 并選擇或創建一個項目。 打開項目設置&#xff1a; 在 Windows/Linux 上&#xff0c;可以通過點擊…

Windows系統編程項目(四)窗口管理器

本章我們講解基于對話框的MFC窗口相關的操作 該管理器要實現以下功能 初始化列表 初始化列表表頭 初始化圖像列表 初始化列表 功能實現 加載菜單 刷新列表 結束進程 隱藏窗口 最大化窗口 最小化窗口 手搓窗口管理器 // CWindowManage.cpp: 實現文件 //#include "pch.h&…

優化 NFS 掛載參數以提升可靠性與容錯性

在現代 IT 基礎設施中&#xff0c;NFS&#xff08;網絡文件系統&#xff09;被廣泛用于共享文件和存儲。雖然 NFS 提供了便利&#xff0c;但在某些情況下&#xff0c;掛載失敗或網絡問題可能導致掛載操作不穩定。為了提高掛載的可靠性和容錯性&#xff0c;我們可以通過優化 NFS…

JavaScript事件循環機制

JavaScript 事件循環機制&#xff08;Event Loop&#xff09;詳解 JavaScript 是 單線程、非阻塞 語言&#xff0c;依賴 事件循環&#xff08;Event Loop&#xff09; 來實現異步編程。它的執行模型包括 調用棧&#xff08;Call Stack&#xff09;、任務隊列&#xff08;Task …

大模型架構記錄4-文檔切分 (chunks構建)

chunks&#xff1a; 塊 trunks : 樹干 “RAG”通常指 檢索增強生成&#xff08;Retrieval-Augmented Generation&#xff09; 主要框架&#xff1a;用戶提query&#xff0c;找到和它相關的&#xff0c;先把問題轉換為向量&#xff0c;和向量數據庫的數據做比較&#xff0c;檢…

物聯網IoT系列之MQTT協議基礎知識

文章目錄 物聯網IoT系列之MQTT協議基礎知識物聯網IoT是什么&#xff1f;什么是MQTT&#xff1f;為什么說MQTT是適用于物聯網的協議&#xff1f;MQTT工作原理核心組件核心機制 MQTT工作流程1. 建立連接2. 發布和訂閱3. 消息確認4. 斷開連接 MQTT工作流程圖MQTT在物聯網中的應用 …

第27周JavaSpringboot電商進階開發 1.企業級用戶驗證

課程筆記&#xff1a;注冊郵箱驗證 一、概述 從本小節開始&#xff0c;將學習如何進行注冊郵箱驗證。主要任務是給項目配置一個公共郵箱&#xff08;可自己注冊或由公司提供&#xff09;&#xff0c;用于向用戶發送驗證碼&#xff0c;幫助用戶完成注冊流程。課程中以QQ郵箱為…

數據庫---sqlite3

數據庫&#xff1a; 數據庫文件與普通文件區別: 1.普通文件對數據管理(增刪改查)效率低 2.數據庫對數據管理效率高,使用方便 常用數據庫: 1.關系型數據庫: 將復雜的數據結構簡化為二維表格形式 大型:Oracle、DB2 中型:MySql、SQLServer …

音視頻軟件工程師面試題

一、基礎知識 編解碼相關 H.264 和 H.265(HEVC)的主要區別是什么?視頻編解碼的基本流程是什么?關鍵技術有哪些?音頻編解碼(如 AAC、MP3、Opus)的區別和應用場景?什么是 B 幀、P 幀、I 幀?它們的作用是什么? 流媒體協議RTMP、HTTP-FLV、HLS、WebRTC 的區別和應用場景…

【系統架構設計師】測試方法

目錄 1. 說明2. 靜態測試3. 動態測試4. 黑盒測試5. 白盒測試6. 灰盒測試7. 自動化測試8.例題8.1 例題1 1. 說明 1.軟件測試方法的分類有很多種&#xff0c;以測試過程中程序執行狀態為依據可分為靜態測試&#xff08;Static Testing&#xff0c;ST&#xff09;和動態測試&…

tomcat配置應用----server.xml文件具體配置

1.tomcat項目目錄 默認項目目錄&#xff1a;tomcat安裝目錄/webapps目錄 如上圖所示&#xff0c;在tomcat的項目目錄下有很多子文件夾&#xff0c;這些子文件夾中都有一個項目首頁。 如上圖所示&#xff0c;將來我們去使用IP加端口號的方式去訪問tomcat的時候&#xff0c;默認是…

Spring Boot 調用DeepSeek API的詳細教程

目錄 前置準備步驟1&#xff1a;創建Spring Boot項目步驟2&#xff1a;配置API參數步驟3&#xff1a;創建請求/響應DTO步驟4&#xff1a;實現API客戶端步驟5&#xff1a;創建控制器步驟6&#xff1a;異常處理步驟7&#xff1a;測試驗證單元測試示例Postman測試請求 常見問題排查…

多維數據聚合方案:SQL GROUPING SETS深度解析

一、什么是GROUPING SETS&#xff1f; GROUPING SETS是SQL標準中的多維聚合運算符&#xff0c;允許在單個查詢中實現多維度組合的分組統計。相較于傳統UNION ALL方案&#xff0c;性能可提升3-10倍&#xff08;TPC-DS基準測試&#xff09;。 二、核心語法解析 SELECT column1,…

Excel中國式排名,3種方法!

大家好&#xff0c;我是小魚。 什么是中國式排名呢&#xff1f; 舉個例子比如說公司一共有10名員工進行成績考核&#xff0c;如果9個人考核成績都是90分&#xff0c;你是89分&#xff0c;按照國際慣用的排名法則&#xff1a;9 個人考核成績并列第一&#xff0c;你第10名&…

哪些業務場景更適合用MongoDB?何時比MySQL/PostgreSQL好用?

哪些業務場景更適合用MongoDB&#xff1f;何時比MySQL/PostgreSQL好用&#xff1f; 就像淘寶的個性化推薦需要靈活調整商品標簽&#xff0c;MongoDB這種"變形金剛"式的數據庫&#xff0c;在處理以下三類中國特色業務場景時更具優勢&#xff1a; 一、動態數據就像&q…

深度解讀:OpenAI發布GPT-5的技術突破與商業影響

引言 2025年2月&#xff0c;OpenAI正式發布GPT-5&#xff0c;這一被譽為“AI新紀元開篇之作”的模型&#xff0c;不僅實現了技術架構的顛覆性創新&#xff0c;更以免費開放策略引發行業地震。本文將從技術突破、商業影響、行業競爭格局及未來挑戰四個維度&#xff0c;全面解析…

網絡防火墻是什么有什么用_網絡防火墻:守護信息安全的重要屏障

網絡防火墻的基本概念 網絡防火墻是網絡安全領域的重要組成部分&#xff0c;它充當著內部網絡和外部網絡之間的安全防護層。防火墻能夠監控和控制進出網絡的數據流&#xff0c;只允許符合安全策略的信息通過&#xff0c;從而有效阻止潛在威脅的入侵。簡而言之&#xff0c;網絡…