文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue3怎么通过render函数实现菜单下拉框

2023-07-06 03:56

关注

这篇文章主要介绍“vue3怎么通过render函数实现菜单下拉框”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue3怎么通过render函数实现菜单下拉框”文章能帮助大家解决问题。

技术方案

先写一个下拉框组件

首先,我们先写一个组件,用来展示下拉框内容。组件名称起为 :Select.vue

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

vue3怎么通过render函数实现菜单下拉框

渲染组件

我们要将这个组件渲染在网页上,操作应该是这样的:

当鼠标移动到产品服务时,将下拉框组件作为一个组件实例渲染在页面的合适位置。

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函数实现菜单下拉框”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯