ホームページ >ウェブフロントエンド >Vue.js >vue3のrefを通じて要素ノードを取得する方法

vue3のrefを通じて要素ノードを取得する方法

PHPz
PHPz転載
2023-05-16 12:25:065155ブラウズ

ref

ref を通じて要素ノードを取得する vue2 では、js ネイティブの document.getElementById("#id") 操作を簡略化すると言えます。もちろん、vue3 でも同様です。

まず、取得したい要素に ref 属性を与えます。

vue3のrefを通じて要素ノードを取得する方法

次に、ref オブジェクトを作成し、その後、彼の値にアクセスできるようになります。

しかし。これにはセットアップでアクセスできますが、直接出力される値は null です...

vue3のrefを通じて要素ノードを取得する方法

セットアップ関数の実行時間は HTML タグのレンダリングよりも前でなければならないため、セットアップ関数でボックスタグを直接初期化することはできません。

#ライフサイクル関数では、beforeCreateとCreatedの間にsetup関数が実行されます

#初期化などの操作がある場合は、ライフサイクル関数でonMountedを借用する必要があります

vue3のrefを通じて要素ノードを取得する方法この方法でアクセスできます

vue3のrefを通じて要素ノードを取得する方法ref 要素を取得するいくつかの方法のまとめ

1. dom 要素を取得しますネイティブ JS の場合

document.querySelector(选择器)
document.getElementById(id选择器)
document.getElementsByClassName(class选择器)

2. ref は単一の dom 要素を取得します

<template>
   <div ref=&#39;divDom&#39;></div> 
</template>
<script setup>
import { ref} from &#39;vue&#39;
const divDom = ref(null);
onMounted(()=>{
    console.log(&#39;获取dom元素&#39;,divDom)
})

3. ref は v-for ループで dom 要素を取得します##
<template>
   <div ref=&#39;getDivDom&#39; v-for="item in list" :data-id="item.id"></div> 
</template>
<script setup>
import { ref} from &#39;vue&#39;
const divDomList = ref(new Map());

const getDivDom = el=>{
    if(el){
        divDomList.set(el.dataset[&#39;id&#39;],el) 
    }
}
// const el =divDomList.get(id) // 根据list数据中的id值 获取对应的dom元素

4. dom を取得しますswiper

<template>
   <swiper @swiper=&#39;getSwiper&#39;></swiper > 
</template>
<script setup>
import swiper from &#39;swiper&#39;
import { ref} from &#39;vue&#39;
const swiperDom= ref(null);

const getSwiper= el=>{
    swiperDom.value = el;
}
の swiper の要素

以上がvue3のrefを通じて要素ノードを取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。