欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3?setup語法糖中獲取slot插槽的dom對象代碼示例

 更新時間:2024年04月19日 10:03:52   作者:WJP丶  
slot元素是一個插槽出口,標示了父元素提供的插槽內容將在哪里被渲染,這篇文章主要給大家介紹了關于vue3?setup語法糖中獲取slot插槽的dom對象的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

前言

最近使用vue3開發(fā)項目,需要封裝一個無限滾動的組件,使用scroll組件內置插槽接受模板的方式,所以需要在scroll組件內獲取到模板渲染后dom元素的寬高。

但是setup語法糖是組件生命周期的beforeCreate和created中,而且經過測試,在mounted函數中的el屬性也是null,所以得出結論模板的slot.default無法直接獲取, 必須通過 render 方式對 slot 的 vnode 進行渲染,然后在 render 組件中的 mounted 方法中才能獲取到。如下面的例子

容器組件 ScrollView

//ScrollView.vue  scroll容器組件
<script setup lang="ts">
 import { ref, useSlots } from 'vue'
 import createSlot from '../vnode/createSlot'
 const slot = useSlots()
 // 這里獲取到的是默認插槽的vnode,但拿不到對應的dom實例
 const defaultSlot = slots.default && slots.default()[0]

 // 自定義template 內容mounted事件
 const mountedCallFun = (args)=> {
  console.log('mounted', args)
 }
 // 自定義template 內容updated事件
 const updatedCallFun = (args)=> {
  console.log(args)
 }
 // 自定義template 內容unMounted卸載事件
 const unmountedCallFun = (args)=> {
  console.log(args)
 }
 const mySlot = createSlot({mountedCallFun, updatedCallFun, unmountedCallFun})
 onMounted(() => {
  // 即使在該組件的mounted鉤子中,這個defaultSlot的$el依然為null
  console.log('defaultSlot', defaultSlot)
 })
</script>

<template>
  <div>
    <mySlot :vnode="defaultSlot"></mySlot>
  </div>
</template>

render函數渲染slot內容的工廠函數 createSlots.ts

通過 vue官方提供的 defineComponent創(chuàng)建一個組件裝載 scrollView組件中的 插槽內容:

//createSlots.ts
import { defineComponent, h } from "vue"
type CallFun = (vnodeEl: HTMLElement) => void
type Funs = Record<'mountedCallFun'| 'updatedCallFun'| 'unmountedCallFun', CallFun>
export default ({mountedCallFun, updatedCallFun, unmountedCallFun}: Funs) => {
  return defineComponent({
    props: ['vnode'],
    setup(props, ctx){
      console.log(props, ctx)
    },
    mounted() {
      // console.log(this.$el)
      mountedCallFun(this.$el)
    },
    render(props: any, ctx: any) {
      console.log(props, ctx)
      return props.vnode
    }
  })
}

測試使用 ScrollView組件

<script setup lang="ts">
  import Text from '../components/text.vue'
  import ScrollView from '../components/ScrollView.vue'
</script>

<template>
  <div>
    <ScrollView>
      <h2 >測試使用 ScrollView組件測試使用 ScrollView組件</h2>
      <h2 >測試使用 ScrollView組件測試使用 ScrollView組件</h2>
      <h2 >測試使用 ScrollView組件測試使用 ScrollView組件</h2>
      <h2 >測試使用 ScrollView組件測試使用 ScrollView組件</h2>
    </ScrollView>
  </div>
</template>

總結  

到此這篇關于vue3 setup語法糖中獲取slot插槽的dom對象的文章就介紹到這了,更多相關vue3獲取slot插槽dom對象內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue左右滑動選擇日期組件封裝的方法

    vue左右滑動選擇日期組件封裝的方法

    這篇文章主要為大家詳細介紹了vue左右滑動選擇日期組件封裝的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 基于Vue?+?ElementUI實現可編輯表格及校驗

    基于Vue?+?ElementUI實現可編輯表格及校驗

    這篇文章主要給大家介紹了基于Vue?+?ElementUI?實現可編輯表格及校驗,文中有詳細的代碼講解和實現思路,講解的非常詳細,有需要的朋友可以參考下
    2023-08-08
  • Vue圖片瀏覽組件v-viewer用法分析【支持旋轉、縮放、翻轉等操作】

    Vue圖片瀏覽組件v-viewer用法分析【支持旋轉、縮放、翻轉等操作】

    這篇文章主要介紹了Vue圖片瀏覽組件v-viewer用法,結合實例形式分析了v-viewer的基本功能與使用方法,包括旋轉、縮放、翻轉等操作技巧,需要的朋友可以參考下
    2019-11-11
  • vue使用recorder-core.js實現錄音功能

    vue使用recorder-core.js實現錄音功能

    這篇文章主要介紹了vue如何使用recorder-core.js實現錄音功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • Vue3如何自定義v-permission權限指令

    Vue3如何自定義v-permission權限指令

    這篇文章主要為大家詳細介紹了Vue3如何編寫一個?v-permission?指令來根據用戶權限動態(tài)控制元素的渲染,感興趣的小伙伴可以參考一下
    2024-12-12
  • Vue中的匿名插槽與具名插槽詳解

    Vue中的匿名插槽與具名插槽詳解

    這篇文章主要為大家介紹了Vue中的匿名插槽與具名插槽,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • Vuex中狀態(tài)管理器的使用詳解

    Vuex中狀態(tài)管理器的使用詳解

    這篇文章主要介紹了Vuex狀態(tài)管理器的使用,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • vue項目中axios請求網絡接口封裝的示例代碼

    vue項目中axios請求網絡接口封裝的示例代碼

    這篇文章主要介紹了vue項目中axios請求網絡接口封裝的示例代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • Vue3 setup語法糖銷毀一個或多個定時器(setTimeout/setInterval)

    Vue3 setup語法糖銷毀一個或多個定時器(setTimeout/setInterval)

    這篇文章主要給大家介紹了關于Vue3 setup語法糖銷毀一個或多個定時器(setTimeout/setInterval)的相關資料,vue是單頁面應用,路由切換后,定時器并不會自動關閉,需要手動清除,當頁面被銷毀時,清除定時器即可,需要的朋友可以參考下
    2023-10-10
  • 一個Vue頁面的內存泄露分析詳解

    一個Vue頁面的內存泄露分析詳解

    這篇文章主要介紹了一個Vue頁面的內存泄露分析詳解,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06

最新評論