首頁  >  文章  >  web前端  >  vue3怎麼透過render函數實現選單下拉框

vue3怎麼透過render函數實現選單下拉框

PHPz
PHPz轉載
2023-05-10 16:28:211655瀏覽

技術方案

先寫一個下拉框元件

首先,我們先寫一個元件,用來展示下拉框內容。元件名稱起為: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 &#39;vue&#39;
import component from "./component.vue"
//1、创造包裹虚拟节点的div元素
const container = document.createElement(&#39;div&#39;);
//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(&#39;div&#39;);
  //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(&#39;div&#39;);
  //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([&#39;destroy&#39;])
function beforeUnload(){
 emit(&#39;destroy&#39;)
}
</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(&#39;div&#39;);
  //2、创造虚拟节点
  let vm = createVNode(Select,props)
  //3、将虚拟节点创造成真实DOM
  render (vm, container)
  //4、将渲染的结果放到body下
  document.body.appendChild(container.firstElementChild) 
}

以上是vue3怎麼透過render函數實現選單下拉框的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除