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、将虚拟节点创造成真实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函数实现菜单下拉框的示例的文章就介绍到这了,更多相关vue3 render菜单下拉框内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue使用html2canvas和jspdf将html转成pdf
在前端开发中, html转pdf是最常见的需求,下面这篇文章主要给大家介绍了关于vue如何使用html2canvas和jspdf将html转成pdf的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2022-03-03
vue 使用element-ui中的Notification自定义按钮并实现关闭功能及如何处理多个通知
这篇文章主要介绍了vue 使用element-ui中的Notification自定义按钮并实现关闭功能及如何处理多个通知,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2019-08-08
vue3导入excel并解析excel数据渲染到表格中(纯前端实现)
在Vue中实现导出Excel有多种方式,可以通过前端实现,也可以通过前后端配合实现,下面这篇文章主要给大家介绍了关于vue3导入excel并解析excel数据渲染到表格中的相关资料,文中介绍的方法是纯前端实现,需要的朋友可以参考下2024-04-04


最新评论