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

Vue操作DOM解決顯示位置問題

 更新時間:2024年12月18日 08:28:42   作者:RePeaT  
這篇文章主要介紹了Vue操作DOM解決顯示位置問題,文中通過代碼示例講解的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下

近來遇到的一個需求,簡單記錄一下思考和解決的過程

一、需求

上傳卡片按鈕,可顯示在上傳文件列表的首位,也可顯示在末尾。

簡化代碼如下:

// custom-upload 組件
<div class="wrapper" id="wrapper">
  <el-upload />
  <FilePreview  
    v-for="item in fileList"
    :key="item.id"
    :src="item.url" />
</div>

上傳卡片按鈕和上傳文件列表在一個div元素內(nèi),上傳卡片按鈕是div的第一個子元素,

需要擴展組件功能,上傳卡片按鈕可為div的最后一個元素

二、解決辦法及思路

一、增加prop參數(shù),用來控制上傳卡片的顯示位置,默認在首位

<script lang="ts" setup>
interface IProps {
  position?: 'first' | 'last'
}

const props = withDefaults(defineProps<IProps>(), {
  position: 'first',
})
</script>

二、控制上傳卡片按鈕的位置

(1)第一想法是,直接復(fù)制在一份在<FilePreview/ >后面,

通過參數(shù)控制顯示第一個還是最后一個,

此方法雖然方便快捷,但也有兩點缺點。

<div class="wrapper">
  <el-upload v-if="props.position === 'first'" />
  <FilePreview  
    v-for="item in fileList"
    :key="item.id"
    :src="item.url" />
  <el-upload v-if="props.position === 'last'" />
</div>
  • 代碼重復(fù),不夠優(yōu)雅
  • <el-upload />上屬性多,后期維護,改了第一個組件,容易漏掉最后一個組件,造成bug

(2)為了解決代碼重復(fù)的問題,在想到將<el-upload />組件封裝成組件,不失為一個好辦法,

但是由于<el-upload />上屬性太多,要寫很多prop。

(3)在進一步思考,在本組件內(nèi),可操作DOM,達到移動的目的。上面兩個問題都可以解決

onMounted(() => {
  if (props.position === 'last') { 
    const container: any = document.getElementById('wrapper')
    const firstItem: any = container.firstChild
    container.appendChild(firstItem)
  }
})

在vue中操作DOM的代碼要寫在onMounted中,此時組件掛載完成,DOM可確保獲取到。

操作DOM需要三步:

  • 獲取div父元素:通過document.getElementById獲取div元素
  • 獲取上傳按鈕卡片:通過firstChild屬性,獲取上傳卡片按鈕
  • 移動:在通過appendChild方法移動到div的末尾

DOM操作步驟確定,滿足上面三步的方法,還可以變換,比如:

onMounted(() => {
  if (props.position === 'last') { 
    const container: any = document.querySelector("#wrapper")
    const firstItem: any = container.childNodes[0]
    container.insertBefore(firstItem, null)
  }
})
  • 獲取div父元素:通過document.querySelector獲取div元素
  • 獲取上傳按鈕卡片:通過childNodes屬性的,獲取上傳卡片按鈕
  • 移動:在通過insertBefore方法,將第一個元素插入到最后

三、DOM方法整理

appendChild():用于向元素的末尾添加一個節(jié)點

insertBefore():把節(jié)點放在元素中某個特定的位置上

replaceChild():替換子元素中某個節(jié)點

cloneNode():復(fù)制一個節(jié)點

const container: any = document.getElementById('wrapper')
container.appendChild(newNode)
container.insertBefore(newNode, targetNode)
container.replaceChild(newNode, targetNode)
container.cloneNode() 

到此這篇關(guān)于Vue操作DOM解決顯示位置問題的文章就介紹到這了,更多相關(guān)Vue DOM顯示位置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 一文詳解Vue.js與TypeScript的生命周期

    一文詳解Vue.js與TypeScript的生命周期

    Vue與TypeScript的結(jié)合使得開發(fā)大型應(yīng)用變得更加容易和高效,本文將詳細探討Vue.js組件中TypeScript的應(yīng)用,特別是它的生命周期鉤子函數(shù),并通過豐富的示例,為你提供一個實戰(zhàn)指南,需要的朋友可以參考下
    2023-11-11
  • 解決vite build打包后頁面不能正常訪問的情況

    解決vite build打包后頁面不能正常訪問的情況

    這篇文章主要介紹了解決Vite打包后直接使用瀏覽器打開,顯示空白問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue3封裝自動滾動列表指令(含網(wǎng)頁縮放滾動問題)

    Vue3封裝自動滾動列表指令(含網(wǎng)頁縮放滾動問題)

    本文主要介紹了Vue3封裝自動滾動列表指令(含網(wǎng)頁縮放滾動問題),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • vue2.0中組件傳值的幾種方式總結(jié)

    vue2.0中組件傳值的幾種方式總結(jié)

    這篇文章主要介紹了vue2.0中組件傳值的幾種方式總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue實現(xiàn)自定義表格工具擴展

    vue實現(xiàn)自定義表格工具擴展

    這篇文章主要為大家詳細介紹了vue實現(xiàn)自定義表格工具擴展,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue3中使用ant-design-vue的layout組件實現(xiàn)動態(tài)導航欄和面包屑功能

    vue3中使用ant-design-vue的layout組件實現(xiàn)動態(tài)導航欄和面包屑功能

    這篇文章主要介紹了vue3中使用ant-design-vue的layout組件實現(xiàn)動態(tài)導航欄和面包屑功能,基于一個新建的Vue3項目上實現(xiàn),本文結(jié)合示例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2023-01-01
  • vue+echarts實現(xiàn)數(shù)據(jù)實時更新

    vue+echarts實現(xiàn)數(shù)據(jù)實時更新

    這篇文章主要為大家詳細介紹了vue+echarts實現(xiàn)數(shù)據(jù)實時更新,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 基于Vue實現(xiàn)一個"蛇形"步驟條

    基于Vue實現(xiàn)一個"蛇形"步驟條

    在現(xiàn)代Web應(yīng)用中,步驟條作為一種常見的UI組件,廣泛應(yīng)用于表單提交、任務(wù)進度以及多步驟操作等場景,下面我們來看看如何利用Vue實現(xiàn)一個蛇形步驟條吧
    2024-11-11
  • vuex中commit和dispatch的區(qū)別解析

    vuex中commit和dispatch的區(qū)別解析

    commit 和dispatch的區(qū)別在于commit是提交mutatious的同步操作,dispatch是分發(fā)actions的異步操作,本文重點給大家講解vuex中commit和dispatch的區(qū)別,感興趣的朋友一起看看吧
    2024-06-06
  • Vue 多層組件嵌套二種實現(xiàn)方式(測試實例)

    Vue 多層組件嵌套二種實現(xiàn)方式(測試實例)

    本篇文章主要介紹了Vue組件嵌套二種實現(xiàn)方式(測試實例),具有一定的參考價值,代碼很簡單,感興趣的小伙伴們可以參考一下
    2017-09-09

最新評論