技术方案先写一个下拉框组件首先,我们先写一个组件,用来展示下拉框内容。组件名称起为 :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、将虚拟节点创造成真实domrender (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、将虚拟节点创造成真实dom render (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、将虚拟节点创造成真实dom render (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>
父组件里,我们需要在props中添加一个ondestroy函数,注意:ondestroy是驼峰式写法
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、将虚拟节点创造成真实dom render (vm, container) //4、将渲染的结果放到body下 document.body.appendchild(container.firstelementchild) }
以上就是vue3怎么通过render函数实现菜单下拉框的详细内容。