ホームページ >ウェブフロントエンド >jsチュートリアル >Vue.jsでのwatchの使い方を詳しく解説

Vue.jsでのwatchの使い方を詳しく解説

黄舟
黄舟オリジナル
2017-05-26 10:20:461791ブラウズ

この記事では、Vue.jsでの$watchの使い方を主に紹介しています。エディターをフォローして見てみましょう

この 2 日間で、Vue.js の $watch について多くのことを学びました。これは非常に重要なので、今日はいくつかメモを追加します。

githubソースコード

Observer、Watcher、vmはVueのより重要な部分であり、データ変更を検出した後のview更新の重要な部分であると言えます。単純な $watch 関数を実装する方法を見てみましょう。もちろん、Vue は多くの最適化メソッドを使用しますが、この記事では 1 つずつ説明しません。

例:

// 创建 vm
let vm = new Vue({
 data: 'a'
})

// 键路径
vm.$watch('a.b.c', function () {
 // 做点什么
})

まず、このデモと Vue での関係を明確にします:

vm $watch を呼び出した後、まず Observer 関数 を呼び出してデータを観察する Observer インスタンスを作成し、Observer は Dep を作成します。これはサブスクリプションを維持するために使用されます。次に、update 関数を提供する Watcher インスタンスを作成します。データが変更されると、コールバック関数がレイヤーごとに実行されます。


Observer と観察

再帰的 Observer 関数を呼び出して、Observer を作成します。 Observer を作成するプロセスで、Object.defineProperty() 関数を使用して get set 関数を追加し、Dep インスタンスを作成します。

export function observe (val) {
 if (!val || typeof val !== 'object') {
  return
 }
 return new Observer(val)
}
rreeee

Dep.target とは一体何なのか疑問に思うかもしれません。

以上がVue.jsでのwatchの使い方を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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