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

PHPz
リリース: 2023-05-16 12:25:06
転載
5087 人が閲覧しました

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 までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート