Vue3でwatchEffectリスナーを使用する方法
watchEffect リスナー
実は、これは役に立たないと思うので、使用しないでください、ははははは!
なんと言うか、watchとwatchEffectの機能は同じであることが分かります。
watch
: 指定した依存元を表示し、依存元が更新されたときにコールバック関数を実行します。 watchEffect
: 依存関係ソースを自動的に収集し、依存関係ソースが更新されたときにそれ自体を再実行します。
watchEffect 存在する場合、コンポーネントは初期化時に 1 回だけ自動的に実行されます。watch のように即時実行するように設定する必要はありません。
watch 各コールバックの後、最新の値と最後の古い値を取得できますが、watchEffect はそれを取得できません。
watchEffect は監視するプロパティを指定する必要はありません。自動的に依存関係を収集します。コールバックで応答性の高いプロパティを使用している限り、これらのプロパティが設定された後にコールバックが実行されます。いいえ watch と同様に、指定されたプロパティのみを監視できます。使用する場合は
# も導入する必要があります。
watch は watchEffect を置き換えることができますが、watchEffect は watch を置き換えることはできないことに注意してください。
要約: watch を使用できる場合は、watchEffect を使用しないでください。
watchEffect リスナーの使用法
最初に、単純な watchEffect リスナーを作成します。
<template> <div> <h2>{{name}}</h2> <button @click="btn">修改name</button> </div> </template> <script> import { ref, watchEffect } from "vue"; export default { name: "App", setup() { const name = ref("我是????????."); function btn() { name.value = "????????."; } const res = watchEffect(() => { console.log("watchEffect 执行了"); }); return { name, btn }; } }; </script>
最初に watchEffect を導入する必要があることに注意してください。そうしないと使いにくくなります。次に、上記のコードを保存し、ページを更新して実行結果を確認します。
ページを更新するとすぐに、出力したコンテンツがコンソールに直接出力されることがわかりました。そのため、watchEffect コンポーネントはロードされるとすぐに実行されます。
watchEffect は基本データを監視します
watchEffect を使用する場合、監視するパラメータは設定されておらず、コールバック関数が 1 つだけであることがわかります。これは、これを使用する限り依存関係が自動的に収集されるためです。コールバック Responsive プロパティの場合、このコールバックはこれらのプロパティが変更された後に実行されます。
たとえば、名前を監視する場合。
<template> <div> <h2>{{name}}</h2> <button @click="btn">修改name</button> </div> </template> <script> import { ref, watchEffect } from "vue"; export default { name: "App", setup() { const name = ref("我是????????."); function btn() { name.value = "????????."; } const res = watchEffect(() => { console.log(name.value); }); return { name, btn }; } }; </script>
コールバック関数の name の値を出力します。
watchEffect 複雑なデータの監視
上記の例は基本的なデータの監視に使用されていますが、オブジェクトを監視する場合はどうなるでしょうか?
実は、同じなんです。
<template> <div> <h2>{{boy.age}}</h2> <button @click="boy.age++">修改name</button> </div> </template> <script> import { ref, watchEffect, reactive } from "vue"; export default { name: "App", setup() { const boy = reactive({ name: "我是????????.", age: 10 }); const res = watchEffect(() => { console.log(boy.age); }); return { boy }; } }; </script>
上記のコードでは、ボタンがクリックされるたびにboyオブジェクトの年齢に1を加算し、新しい年齢の値を監視します
全く問題なし!
watchEffect はいつ実行されますか?
上で述べたように、コールバックで応答性の属性を使用している限り、監視のみが可能な watch とは異なり、コールバックはこれらの属性が変更された後に実行されます。 . 指定された属性。
これはどういう意味ですか? 簡単に理解すると、コールバックで使用されていれば実行され、使用されていない場合は実行されません。
上記の場合と同様に、年齢を変更する場合、コールバックに年齢を出力します。コールバックに年齢が含まれている場合は実行されます。今回変更された年齢を使用しない場合は、のみ実行されます。 print つまり、コールバックを実行できるかどうかを見てみましょう。
<template> <div> <h2>{{boy.age}}</h2> <button @click="boy.age++">修改name</button> </div> </template> <script> import { ref, watchEffect, reactive } from "vue"; export default { name: "App", setup() { const boy = reactive({ name: "我是????????.", age: 10 }); const res = watchEffect(() => { console.log("执行了"); }); return { boy }; } }; </script>
更新して保存し、ボタンをクリックして age の値を変更し、コンソールに executed
という文字が出力されるかどうかを確認します。
その文わかりますか?いつ処刑されたか知っていますか?わかりました。
watchEffect モニタリングをオフにする
watchEffect モニタリングの使用を開始するとします。しかし、今はモニタリングしたくない場合はどうすればよいでしょうか?実はとてもシンプルなのです。
const res = watchEffect(() => { console.log(boy.age); });
上で watchEffect リスナーを作成しませんでしたか?閉じるには、一度呼び出すだけで閉じられます。
res() // 关闭
以下の具体的なコードを見てください。
<script> import { ref, watchEffect, reactive } from "vue"; export default { name: "App", setup() { const boy = reactive({ name: "我是????????.", age: 10 }); const res = watchEffect(() => { console.log(boy.age); }); res() // 关闭监听 return { boy }; } }; </script>{{boy.age}}
保存し、ボタンをクリックして効果を確認します。
以上がVue3でwatchEffectリスナーを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









vue3+vite:src は、イメージとエラー レポートと解決策を動的にインポートするために require を使用します。vue3+vite は複数のイメージを動的にインポートします。vue3。TypeScript 開発を使用している場合、イメージを導入するために require のエラー メッセージが表示されます。requireisnotdefined は使用できません。 vue2 のような imgUrl:require(' .../assets/test.png') は、typescript が require をサポートしていないため、インポートされます。そのため、import が使用されます。解決方法は次のとおりです: awaitimport を使用します

tinymce はフル機能のリッチ テキスト エディター プラグインですが、tinymce を vue に導入するのは他の Vue リッチ テキスト プラグインほどスムーズではありません。tinymce 自体は Vue には適しておらず、@tinymce/tinymce-vue を導入する必要があります。外国のリッチテキストプラグインであり、中国語版を通過していないため、公式 Web サイトから翻訳パッケージをダウンロードする必要があります (ファイアウォールをバイパスする必要がある場合があります)。 1. 関連する依存関係をインストールします npminstalltinymce-Snpminstall@tinymce/tinymce-vue-S2. 中国語パッケージをダウンロードします 3. スキンと中国語パッケージを導入します. プロジェクトのパブリック フォルダーに新しい tinymce フォルダーを作成し、

Vue はブログ フロントエンドを実装しており、マークダウン解析を実装する必要があり、コードがある場合はコードのハイライトを実装する必要があります。 Vue には、markdown-it、vue-markdown-loader、marked、vue-markdown など、マークダウン解析ライブラリが多数あります。これらのライブラリはすべて非常に似ています。ここではMarkedが使用され、コード強調表示ライブラリとしてhighlight.jsが使用されます。 1. 依存ライブラリをインストールする vue プロジェクトの下でコマンド ウィンドウを開き、次のコマンド npminstallmarked-save//marked を入力して、マークダウンを htmlnpmins に変換します。

ページの部分的な更新を実現するには、ローカル コンポーネント (dom) の再レンダリングを実装するだけで済みます。 Vue でこの効果を実現する最も簡単な方法は、v-if ディレクティブを使用することです。 Vue2 では、v-if 命令を使用してローカル dom を再レンダリングすることに加えて、新しい空のコンポーネントを作成することもできます。ローカル ページを更新する必要がある場合は、この空のコンポーネント ページにジャンプしてから、再びジャンプします。 beforeRouteEnter ガードを空白のコンポーネントに配置します。元のページ。以下の図に示すように、Vue3.X の更新ボタンをクリックして赤枠内の DOM を再読み込みし、対応する読み込みステータスを表示する方法を示します。 Vue3.X の scriptsetup 構文のコンポーネントのガードには o しかないので、

はじめに vue であれ、react であれ、複数の繰り返しコードに遭遇した場合、ファイルを冗長なコードの束で埋めるのではなく、これらのコードを再利用する方法を考えます。実際、vue と React はどちらもコンポーネントを抽出することで再利用を実現できますが、小さなコードの断片に遭遇し、別のファイルを抽出したくない場合は、それに比べて、React は同じファイル内で対応するウィジェットを宣言して使用できます。または、次のような renderfunction を通じて実装します。 constDemo:FC=({msg})=>{returndemomsgis{msg}}constApp:FC=()=>{return(

最終的な効果は、VueCropper コンポーネントのyarnaddvue-cropper@next をインストールすることです。上記のインストール値は Vue3 用です。Vue2 の場合、または他の方法を参照したい場合は、公式 npm アドレス: 公式チュートリアルにアクセスしてください。また、コンポーネント内で参照して使用するのも非常に簡単です。必要なのは、対応するコンポーネントとそのスタイル ファイルを導入することだけです。ここではグローバルに参照しませんが、import{userInfoByRequest}from'../js/api を導入するだけです。 ' コンポーネント ファイルにインポートします。import{VueCropper}from'vue-cropper&

Vue を使用してカスタム要素を構築する WebComponents は、開発者が再利用可能なカスタム要素 (カスタム要素) を作成できるようにする一連の Web ネイティブ API の総称です。カスタム要素の主な利点は、フレームワークがなくても、任意のフレームワークで使用できることです。これらは、異なるフロントエンド テクノロジ スタックを使用している可能性のあるエンド ユーザーをターゲットにする場合、または最終アプリケーションを使用するコンポーネントの実装の詳細から切り離したい場合に最適です。 Vue と WebComponents は補完的なテクノロジであり、Vue はカスタム要素の使用と作成に対する優れたサポートを提供します。カスタム要素を既存の Vue アプリケーションに統合したり、Vue を使用してビルドしたりできます。

vue3+ts+axios+pinia で無意味なリフレッシュを実現 1. まず、プロジェクト内の aiXos と pinianpmipinia をダウンロードします--savenpminstallaxios--save2. axios リクエストをカプセル化-----ダウンロード js-cookienpmiJS-cookie-s// aixosimporttype{AxiosRequestConfig , AxiosResponse}from"axios";importaxiosfrom'axios';import{ElMess
