ホームページ >ウェブフロントエンド >jsチュートリアル >refs を使用して vue で dom を検索する方法の詳細な説明と、未定義が表示される

refs を使用して vue で dom を検索する方法の詳細な説明と、未定義が表示される

小云云
小云云オリジナル
2017-12-22 09:10:403008ブラウズ

dom ノードを見つけるために ref を使用するのは非常に便利だといつも感じています。しかし、その間に問題が発生しました。つまり、mounted(){} フックで this.$refs.xxx が使用されると、出力される値が未定義になります。

そこで、以前に ref を使用して配置された .vue ファイルを比較し、それらの違いを見つけました。この記事では主に、Vue で refs を使用して DOM 内で未定義を検索する問題の解決策を紹介します。編集者はこれが非常に優れていると考えたので、参考として共有します。編集者をフォローして見てみましょう。皆さんのお役に立てれば幸いです。

特定の DOM ノードが見つからない理由を知りたい場合は、まず、mounted(){} フック関数が何に使用されているかを理解する必要があります。

以下はvue公式が示したvueのライフサイクル(一部)です。公式が言っているように、最初は理解する必要はありませんが、学習して使用するにつれて、その基準値はどんどん高くなります。 。

マウントされた段階で DOM 構造の準備ができていることがわかりますが、ここでの準備については特別な説明が必要です:

DOM 構造は出てきましたが、v-if、v-show、または v-for の場合(つまり、取得したバックグラウンド データに基づいて DOM を動的に操作する、つまりレスポンシブに動作させる) 場合、これらの DOM はマウントされたステージで見つかりません。

この時点でマウントされたステージは、通常、バックエンドリクエストを開始し、データを取得し、ルーティングフックでいくつかの処理を実行するために使用されます。簡単に言えば、マウントされたフックにデータをロードするだけです。ロードされたデータは返されません。この段階では、更新された DOM 内で

したがって、マウントされたフックで $refs を使用する場合、ref が v-if、v-for、v-show で DOM ノードに配置されている場合、戻り値は未定義のみになります。なぜなら、マウントされたステージではそれらはまったく存在しないからです。 !

検査の結果、上記のテキストは間違っています。$refs が見つからない主な理由は、v-if、v-for、v-show などのステートメントが親コンポーネントによって渡されたパラメーターに依存しているためです。 in Mounted() ステージはまだ取得されていません~~~~! ! ! !

DOM がロードされた後に実際にデータを取得したい場合は、VUE のグローバル API を呼び出す必要があります: this.$nextTick(() => {})

マウントされたステージがロード ステージの場合、更新されたstage これで、DOM へのデータ更新 (ロードされたデータの処理) の段階が完了します。この時点で、ref、data などはすべて DOM 構造にマウントされます。更新ステージでは、this.$refs.xxx を使用します。これは 100 です。 %DOM ノードを見つけることができます。

updated と mount の違いは、DOM 構造が更新されるたびに vue が updated(){} フック関数を呼び出すことです。そして、マウントは一度だけ実行されます

簡単に言うと、デバッグ中に要素の存在が確認できれば、this.$refs.xxx を使用して、更新された段階で対応する DOM ノードを見つけることができます。

$refs の使用に関して、公式ドキュメントには具体的に次のヒントが記載されています:

使用するときは注意してください。

関連する推奨事項:

JavaScript における未定義と null の違いの詳細な説明

PHP 実行時の未定義インデックス プロンプトの解決策

PHP 実行中の未定義関数curl_init() の呼び出しの解決策

以上がrefs を使用して vue で dom を検索する方法の詳細な説明と、未定義が表示されるの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。