公式サイトの説明: コンポーネントを定義する場合、コンポーネントは複数のインスタンスを作成するために使用される可能性があるため、データは初期データ オブジェクトを返す関数として宣言する必要があります。データが純粋なオブジェクトのままであれば、すべてのインスタンスが同じデータ オブジェクトへの参照を共有することになります。データ関数を提供することで、新しいインスタンスが作成されるたびに、データ関数を呼び出して初期データ オブジェクトの新しいコピーを返すことができます。面接官が面接中にこの質問をしたのを見たとき、私はその時混乱し、その理由について考えたことはありませんでした。ただ、コードはこのように書く必要があるとわかっていました。最近時間ができたら、この部分の原理についてさらに詳しく学ぶために戻ってきます。私が答えたい質問が 2 つあります。 1. インスタンスを繰り返し作成する際に同じデータを共有することで発生するデータ汚染を回避するため 2. 関数を記述する理由は、オブジェクトの独立性を保証するためです。オブジェクトが一意であることを保証できる場合は、関数を記述せずにオブジェクトを直接記述できます。 実際のところ、すべてはデータ汚染を避けることに帰着します。 この問題を解決したいのであれば、プロトタイプチェーンなどについて話し合う必要があります。 関連する知識を自分で学ぶことができます。オブジェクトはプロトタイプ チェーン内で共通のプロパティとメソッドを共有します。 Person1 と person2 は Person への参照であるため、person2 がデータを変更すると、実際に変更されるのは Person のデータです。 Personのデータが変更されたため、Person1の参照も変更されます。 関数Person(){ } Person.prototype.datas={ a:"c", f:'h' } var person1 = 新しいPerson() var person2 = 新しいPerson() person2.datas.a="wewew" コンソールログ(人2) コンソールログ(人1) 私はいつも疑問を抱いていました。person1 と person2 はどちらも Person への参照であるのに、なぜそれらをオブジェクト内に配置するとデータ汚染が発生し、メソッド内に配置するとデータ汚染が発生しないのでしょうか?まず、1 つ知っておくべきことがあります。関数が定義されているときには、 this の方向は決定できません。関数が実行されたときにのみ、 this が実際に指している対象を決定できます。実際、 this は、それを呼び出すオブジェクトを指します。もう一つ質問があります。同じ方法を指しているのに、なぜ結果が異なるのでしょうか?彼はクローンを作ったのですか?回答: コンストラクター内で定義されたメソッドは、各インスタンスに複製されます。コンストラクターの 関数Person(){ this.datas = this.sayHello() //this はそれを呼び出すオブジェクトを参照します} Person.prototype.sayHello = 関数 () { 戻る { d:1、 2:2 です } }; var person1 = 新しいPerson() var person2 = 新しいPerson() person2.datas.d="wewew" コンソールログ(人1) コンソールログ(人2) 具体的な例は以下のとおりです 1. 通常状態では、データ機能を使用する場合、データ汚染は発生しません。 <em id="__mceDel">ButtonTest.vue<br><テンプレート> <div> <div>{{ カウント }}</div> <button @click="onAdd">追加</button> </div> </テンプレート> <スクリプト> エクスポートデフォルト{ データ() { 戻る { カウント: 0, }; }, メソッド: { 追加() { this.count++; }, }, }; </script><br></em> ホーム.vue <テンプレート> <div class="home"> <ボタンテスト></ボタンテスト> <ボタンテスト></ボタンテスト> </div> </テンプレート> <スクリプト> "@/components/ButtonTest.vue" から ButtonTest をインポートします。 エクスポートデフォルト{ 名前: "ホーム", コンポーネント: ボタンテスト、 }, }; </スクリプト> 2. データがオブジェクトとして直接定義されている場合、エラーが報告されます 3. 外部オブジェクトのフォームを定義し、ボタンをクリックすると、2つのデータが同時に追加され、データ汚染が発生します。 これまでのところ、この記事では、なぜ vue データが関数であるのかについて説明しています。記事はこれで終わりです。vueデータ関数の関連コンテンツについては、123WORDPRESS.COMの過去の記事を検索するか、以下の関連記事を引き続き閲覧してください。今後とも123WORDPRESS.COMをよろしくお願いいたします。 以下もご興味があるかもしれません:
|
ユーザーテーブル、ID番号は一意である必要があります、携帯電話番号、電子メールアドレスは一意である必...
CEP - 複合イベント処理。ご注文後、一定期間内にお支払いの確認が取れませんでした。タクシーの配...
1. 丸い境界線: CSSコードコンテンツをクリップボードにコピー境界線の半径: 4px ; 2....
目次移行ツールアプリケーション変換mysql8.0 ドライバ パッケージを追加データソース構成の変更...
この記事では、jsを使用してクールな花火効果を実現するための具体的なコードを参考までに共有します。具...
DockerでOracle_11gをインストールする1. oracle_11gイメージを取得する d...
1.すべてのIPアドレスが3つのページa1.htm、a2.htm、a3.htmにアクセスするのを禁止...
IE には長い間問題がありました。誰もがテストを受けたとき、誰もが笑顔でしたが、それはただのニヤニヤ...
序文バックエンド開発では、一度に大量のデータがロードされ、メモリやディスク IO のオーバーヘッドが...
nginx プロセス モデルでは、トラフィック統計、トラフィック制御、データ共有などのタスクを完了す...
目次概要1. 関数デバウンス2. 機能スロットリング(スロットル)概要関数アンチシェイクと関数スロッ...
1. まず、自分のdockerhubアカウントを登録します。登録アドレス: https://hub....
重要なのは、ローカルサーバーに書き込み権限がないことですキーはここにあります(アクセス拒否)。私は肯...
本日は、色彩の応用に関する優れた事例を 30 件集めて、皆さんにご紹介したいと思います。これらの事例...
目次MySQL 5.6以前MySQL 5.6以降要約する知らせMySQL 5.6以前更新手順元のテー...