Vue の vue.$set() メソッドのソースコード例の詳細な説明

Vue の vue.$set() メソッドのソースコード例の詳細な説明

Vue を使用してプロジェクトを開発する過程で、次のような問題によく遭遇します。Vue のデータでオブジェクトまたは配列 (配列内の値はオブジェクト) が宣言または割り当てられ、オブジェクトに新しい属性が追加された場合、この属性の値が更新されても、ビューは更新されません。

これは、新しく追加された属性がレスポンシブではないため、ビューの更新がトリガーされないためです。通常、静的メソッド Vue.set() またはインスタンスメソッド this.$set() を使用してこれを解決します。使用方法:

オブジェクト: this.$set(ターゲット、キー、値)

配列: this.$set(ターゲット、インデックス、値)

ただし、静的メソッド Vue.set() であってもインスタンスメソッド this.$set() であっても、基礎となる実装ロジックは同じであり、実装ロジックは次のようになります。

/**
 * オブジェクトにプロパティを設定します。新しいプロパティを追加し、
 * プロパティが
 * すでに存在します。
 */
エクスポート関数セット (ターゲット: 配列<any> | オブジェクト、キー: any、値: any): any {
  // まず、渡されたターゲットオブジェクトが未定義、null、プリミティブ(元の値)であるかどうかを判断します。そうでない場合は、警告をスローします。if (process.env.NODE_ENV !== 'production' &&
    (isUndef(ターゲット) || isPrimitive(ターゲット))
  ){
    警告(`未定義、null、またはプリミティブ値にリアクティブ プロパティを設定できません: ${(target: any)}`)
  }
  // ターゲットオブジェクトが配列であり、キーが有効なインデックスであるかどうかを確認します。if (Array.isArray(target) && isValidArrayIndex(key)) {
    // ターゲット配列の長さとキーの大きい方の値をターゲットの長さ属性として取得します。target.length = Math.max(target.length, key)
    // キー位置の要素をスプライスで置き換えます target.splice(key, 1, val)
    戻り値
  }
  // ターゲットオブジェクトにキーがすでに存在する場合は、それを直接割り当てます。if (key in target && !(key in Object.prototype)) {
    ターゲット[キー] = 値
    戻り値
  }
  // ターゲット内のオブザーバーオブジェクトを取得します。const ob = (target: any).__ob__
  // ターゲットがvueインスタンスまたは$dataの場合、直接戻りますif (target._isVue || (ob && ob.vmCount)) {
    process.env.NODE_ENV !== 'production' && 警告(
      'Vue インスタンスまたはそのルート $data にリアクティブ プロパティを追加しないでください ' +
      「実行時 - データ オプションで事前に宣言します。」
    )
    戻り値
  }
  // obが存在しない場合は、ターゲットがレスポンシブなオブジェクトではないことを意味し、ビューの更新をトリガーせずに値が直接割り当てられます。if (!ob) {
    ターゲット[キー] = 値
    戻り値
  }
  // obが存在する場合は、キーをレスポンシブプロパティとして設定します。defineReactive(ob.value, key, val)
  // ビューの更新をトリガーする通知を送信します ob.dep.notify()
  戻り値
}

上記はvueのsetメソッドのソースコードです。ここで注目すべきは、配列を処理する際に使用されるspliceメソッドは配列自体のメソッドではなく、vueにカプセル化されたレスポンシブな配列メソッドであるということです。

Vue の vue.$set() メソッドの詳細なソースコード事例に関するこの記事はこれで終わりです。Vue の vue.$set() メソッドのソースコードに関するより関連性の高い内容については、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き閲覧してください。皆様の今後の 123WORDPRESS.COM へのご支援をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Vue.$set の失敗の落とし穴の発見と解決
  • Vue での this.$set の動的データバインディングのケーススタディ
  • Vue - 計算プロパティ「****」が割り当てられましたが、セッターがありませんというエラーの解決。
  • vue3.0 でのセットアップの使用 (2 つの使用方法)
  • Vue で resetFields() を使用する際の注意事項について簡単に説明します。

<<:  IDEA で Spring Boot プロジェクトをデプロイするためにリモート サーバー Docker に接続する方法の詳細なチュートリアル

>>:  MySQL マスタースレーブ構成の学習ノート

推薦する

CentOS7.4 起動時の緊急モードへようこそメッセージに対する解決策

今日は仮想マシンを使って実験をしました。システムをインストールし、いくつかのオプションを最適化した後...

初心者でもjsのtypeofとinstanceofの違いを理解できます

目次1. 型2. インスタンス3. 違い1. 型typeof 演算子は、評価されていないオペランドの...

JS 開発効率を上げる4つの超実践的なヒント

目次1. 短絡判定2. オプション連鎖演算子 (?) 3. ヌル合体演算子 (??) 4. 終了関数...

React+Antdはテーブルの追加、削除、変更の例を実装します

目次テーブル/index.jsテーブル/モデル/index.jsテーブル/モデル/モジュール/bas...

K8Sの高度な機能を理解するための記事

目次K8Sの高度な機能高度な機能要約するkubectl サービスの問題のトラブルシューティングK8S...

mysql5.7.17 zip の解凍とインストールの詳細な手順

1. ダウンロードアドレスhttps://dev.mysql.com/downloads/mysql...

77.9K の GitHub リポジトリを持つ Axios プロジェクト: 学ぶ価値のあることは何でしょうか?

目次序文1. Axiosの紹介2. HTTPインターセプターの設計と実装2.1 インターセプターの紹...

vue-resource インターセプターの使用に関する詳細な説明

序文インターセプター最近のフロントエンド フレームワークでは、インターセプターは基本的に非常に基本的...

Vue codemirrorはオンラインコードコンパイラの効果を実現します

序文Web 上でオンライン コード コンパイルの効果を実現したい場合は、 CodeMirrorを再度...

Windows 10 での MySQL 5.7.21 winx64 のインストールと設定方法のグラフィック チュートリアル

mysql 5.7.21 winx64 のインストールと設定方法: MySQLのコミュニティバージョ...

MySQL でパーティション分割後にクエリを実装するために MRG_MyISAM (MERGE) を使用する例

大量のデータベース データを最適化することは非常に高度な科学であり、開発者が習得する必要がある専門的...

MySQL の order by ステートメントの最適化方法の詳細な説明

この記事では、ORDER BY文の最適化について学びます。その前に、インデックスの基礎的な理解が必要...

Reactコンポーネントのライフサイクルの詳細な説明

目次1.ライフサイクルとは何か2. 読み込みプロセス1.コンストラクタ2. レンダリング3. コンポ...

JavaScript の 50 以上のユーティリティ関数の概要

JavaScript は多くの素晴らしい機能を備えています。この記事では、作業効率の向上とコードのデ...

特定の部門 ID に基づいて、すべての下位レベルの複数レベルのサブ部門を照会する MySQL の例

シミュレーションテーブルとデータスクリプト次の SQL ステートメントをコピーして、sys_dept...