vue.jsでdomを取得する方法

coldplay.xixi
リリース: 2020-11-10 11:02:57
オリジナル
2732 人が閲覧しました

DOM を取得するための Vue.js メソッド: 1. HTML の元のタグ ペアまたはサブコンポーネントで ref 属性を定義し、[mounted(){}] メソッドの後に [this.$refs] を使用します。 DOM 要素を取得する ;2. Mounted は、コンポーネントのコンテンツを変更した後も [this.$refs] を使用し続けます。

vue.jsでdomを取得する方法

【関連記事の推奨: vue.js

vue.js が dom を取得しますメソッド:

  • 元のタグ ペアまたは HTML のサブコンポーネントで ref 属性を定義し、mounted(){} メソッドまたは this メソッドの後に this.$refs を使用します。 ref 値は、DOM 要素を取得するために使用されます。以前のマウントされたフック関数を使用するとき、コンポーネントは DOM にマウントされていないため、当然、$refs を通じて DOM 上の要素を取得することはできません。区別されるのは、この .$refs を出力することです。特定の ref 値です。元のタグ ペアの場合、出力結果は元のタグ ペアです。ref 属性がサブコンポーネント タグ内にある場合、出力はコンポーネント オブジェクトです。コンポーネントの対応するテンプレートのコンテンツではありません。

  • this.$refs は、現在のコンポーネントに含まれる ref 属性を定義するタグまたはサブコンポーネントのコレクションを出力します。

  • コンポーネントのレンダリング プロセス中、たとえば、マウント中にコンポーネントのコンテンツを変更した後、引き続き

    this.$refs
  • を使用します。変更されたコンポーネントに対応する参照です。この時点では、取得されるのは変更前の DOM 要素です。変更された DOM 要素を取得するには、 this.$nextTick() メソッドを使用し、このメソッドのコールバック関数で this.$refs を使用する必要があります。変更された DOM 要素が取得されます。もちろん、更新された関数で変更された DOM 要素を取得できますが、特定のシナリオでは、変更された DOM 要素をマウントされた状態で取得する必要があります。
  • <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;meta charset=&amp;#39;utf-8&amp;#39;&gt; &lt;title&gt;Vue组件中获取DOM元素的方式之$refs的使用&lt;/title&gt; &lt;/head&gt; &lt;body&gt; &lt;div id=&amp;#39;app&amp;#39;&gt;&lt;/div&gt; &lt;script type=&amp;#39;text/javascript&amp;#39; src=&amp;#39;node_modules/vue/dist/vue.js&amp;#39;&gt;&lt;/script&gt; &lt;script type=&amp;#39;text/javascript&amp;#39;&gt; Vue.component(&amp;#39;Btn&amp;#39;,{ template:` &lt;button&gt;我是按钮&lt;/button&gt; ` }) let App = { data:function() { return { isShow:false } }, template:` &lt;div&gt; &lt;input type=&amp;#39;text&amp;#39; ref=&amp;#39;input1&amp;#39;/&gt; &lt;input type=&amp;#39;text&amp;#39; ref=&amp;#39;input2&amp;#39; v-show=&amp;#39;isShow&amp;#39;/&gt; &lt;Btn ref=&amp;#39;btn1&amp;#39;/&gt; &lt;/div&gt; `, //对应输出结果为下面第一张图 // mounted:function() { // console.log(this.$refs) // console.log(this.$refs.input1) // console.log(this.$refs.input2) // console.log(this.$refs.btn1) // } mounted:function() { // 修改ref=input2的v-show值,让其显示, 接着获取该DOM并让其获得焦点,但是没法获得焦点,这是因为mounted内无法获得更新DOM后的DOM元素,这个时候需要调用this.$nextTick方法,在其回掉函数中重新执行代码this.$refs.input2.focus() this.isShow = true // this.$refs.input2.focus() this.$nextTick(function() { this.$refs.input2.focus() }) }, } let vm = new Vue({ el:&amp;#39;#app&amp;#39;, data:function() { return { } }, components:{ App }, template:` &lt;App/&gt; ` }) &lt;/script&gt; &lt;/body&gt; &lt;/html&gt;</pre><div class="contentsignin">ログイン後にコピー</div></div> は、注釈付きのマウントされた

のコンテンツ マウントされた状態で this.$nextTick を使用すると、更新された DOM 要素をマウントされた状態で取得できます。このコードでは、更新された DOM 要素にフォーカスを当てます

vue.jsでdomを取得する方法

関連する無料の学習に関する推奨事項:vue.jsでdomを取得する方法javascript

(ビデオ)
##

以上がvue.jsでdomを取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート