概要主に Object.defineProperty を使用して、vue と同様のデータ バインディングを実装します。 最初のステップ定数データ = { 名前: "トム", 年齢: 14 } Object.defineProperty(データ、"名前"、{ 得る(){ 「名前が読み取られました」を返します }, set(val){ console.log('割り当てられました',val) } }) //効果を確認するには、このコードをブラウザコンソールに入力します console.log(data.name) 出力 data.name は tom ではありませんが、name が読み取られます。これは、defineProperty がデータの name フィールドを監視および乗っ取り、name フィールドが返すはずの値を変更するためです。 ステップ2const _data = { ...データ } for(let i in data){ オブジェクト.defineProperty(データ, i, { 得る(){ _data[i]+"jsによって変更されました"を返します }, set(val){ _data[i] = 値; } }) } なぜ別の _data が必要なのでしょうか?回答: データ フィールドが監視され、フィールドの return 属性が変更されます。その結果、データ内の監視対象フィールドが取得されるたびに、ブラウザーは get によって返された値を呼び出します。get で return data[i] を直接返すと、ブラウザーは get メソッドを継続的に呼び出し、無限ループに入ります。 データにもう少しデータを追加する定数データ = { 名前: "トム", 年齢: 14歳 友人: "name1": "張三", "name2": "李思", "name3": "王武", "name4": "趙劉" }, } 初期値の書式設定const createNewWatch = (val, パス, 親キー, イベント) => { //値がオブジェクト型でない場合は、値を直接返します。if(typeof val != 'object') return val; //逆に、オブジェクト型の場合は、WatchObject を呼び出して子要素を走査して監視します //WatchObject は次のコードで作成されます return WatchObject(val,path.concat(parentKey), event) } 広州ブランドデザイン会社 https://www.houdianzi.com オブジェクトのフォーマットと値の監視const WatchObject = (データ、パス、イベント) => { 関数WatchObject(){ for(var key in data){ // 以前に作成した関数を呼び出してvalをフォーマットします data[キー] = createNewWatch(data[キー], パス, キー, イベント) //データキーのリスナーを作成します。defineProperty(this, key, data[key], path.concat(key), event) } } 新しいWatchObject()を返す } 最後にコードを実行すると、簡単なデータ監視が完了します。 定数 b = WatchObject(データ,[],{ set(パス,値){ console.log(パス,値) } }) 上記は、JS を使用して簡単なデータ監視を実装する方法の詳細です。JS データ監視の詳細については、123WORDPRESS.COM の他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
>>: Windows Server 2016 に Oracle をインストールする方法
目次1. 基本2. 問題の説明3. 解決策付録: js を使用して Excel の日付形式を変換する...
最近、MySQL を学び始めました。インストールはスムーズに進み、インターネット上の既成のチュートリ...
ドラッグ機能は主に、ドラッグによる並べ替え、ポップアップ ボックスのドラッグと移動など、ユーザーがカ...
目次I. 概要2. 従来の多段階イメージ構築3. Buildkitを使用してイメージをビルドする4....
注1: MySQLデータベースへの接続が遅い問題を解決するvim /etc/my.cnfコンテン...
勉強や仕事で FTP サーバーを頻繁に使用する場合は、起動時に自動的に起動するように設定できます。設...
目次1. Ubuntuソースの変更2. MySQLをインストールする3. 新しいユーザーを作成し、権...
参考までに、JavaScriptを使用してドロップダウンメニューを実装します。具体的な内容は次のとお...
1. コンポーネントの実装方法:組件名稱首字母必須大寫1. JS関数を通じてコンポーネントを実装...
1. 絶対位置とマージンを使用するこの方法の原則は、左側と右側をドキュメントの流れから外れるように配...
nginx (エンジン x) は、高性能な HTTP およびリバース プロキシ サーバー、メール プ...
MySQL 運用上の問題点を記録します。ビジネスシナリオと問題の説明外部インターフェースをリクエスト...
目次起源仮想メモリページングとページテーブルメモリのアドレス指定と割り当て関数プロセスメモリ管理デー...
この記事では、Xshell と関連する構成の一般的な問題について説明します。この記事の構成は、主に ...
1. Nginxのインストール手順1.1 公式サイトの紹介http://nginx.org/en/d...