JavaScriptプロトタイプ継承の基本的な仕組みの解析_javascriptスキル
この言語機能の本質は、JavaScript の独自のプロトタイプ チェーン パターンに依存しています。
厳密に言えば、JavaScript はプロトタイプに基づいたオブジェクト指向言語です。つまり、すべてのインスタンス オブジェクトにはプロトタイプがあります。オブジェクトは、このプロトタイプからプロパティとメソッドを継承します。
1. コンストラクター
コンストラクターを使用すると、オブジェクトを簡単に作成できます。コンストラクターの this キーワードは、インスタンス オブジェクト自体を指します:
function People(name){
this.name = name;
}
new 演算子とコンストラクターを使用してインスタンス オブジェクトを作成します:
var people = new People('Xiao Ming'); .log(people.name); //Xiao Ming
var people2 = new People('Xiao Wang');
people1.sex = 'male'
console.log(people2.sex); //未定義
2. プロトタイプ
ということで、インスタンス オブジェクトの生成時に自動的に作成されるプロトタイプ プロパティがあります。これはそれ自体がオブジェクトであり、インスタンス間で共有できるプロパティとメソッドを備えています。インスタンス自体のプロパティとメソッドはコンストラクターに含まれます。つまり、コンストラクター内のプロパティとメソッドはインスタンス化後にローカルのプロパティとメソッドになりますが、プロトタイプ内のプロパティとメソッドはインスタンス内の参照にすぎないため、複数のインスタンスで共有して使用できます。
先ほどと同じコンストラクターです。プロトタイプ属性を追加します。
//または People.prototype = {sex: '女性'}; と記述されます。 people1.sex); // 男性
console.log(people2.sex); //女性
People コンストラクターのプロトタイプ属性パラメーターは、people1 と people2 の 2 つのインスタンスに直接影響します。 。
しかし、people1.sex が男性を出力するのはなぜでしょうか? これは、JavaScript ではプロトタイプの関係が再帰的な形式で存在するためです。オブジェクトのプロトタイプもオブジェクトであり、プロトタイプ自体がプロトタイプを持つ場合もあります。最上位のプロトタイプは、グローバル Object オブジェクトです。
これは、people1.sex が man に設定されると、プロトタイプ内の対応する値を公開できないことを意味します。 people1.sex 自体に値がない場合は、コンストラクターのプロトタイプ プロパティから値が読み取られ、同様に Object オブジェクトまで一度に 1 レベルずつ上方向に検索されます。
注: 「null」を使用してオブジェクトに値を割り当てると、カスタム オブジェクトが破棄され、メモリ リソースが解放される可能性があります。

ホット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)

ホットトピック











JavaScript文字列置換法とFAQの詳細な説明 この記事では、javaScriptの文字列文字を置き換える2つの方法について説明します:内部JavaScriptコードとWebページの内部HTML。 JavaScriptコード内の文字列を交換します 最も直接的な方法は、置換()メソッドを使用することです。 str = str.replace( "find"、 "置換"); この方法は、最初の一致のみを置き換えます。すべての一致を置き換えるには、正規表現を使用して、グローバルフラグGを追加します。 str = str.replace(/fi

このチュートリアルでは、カスタムGoogle検索APIをブログまたはWebサイトに統合する方法を示し、標準のWordPressテーマ検索関数よりも洗練された検索エクスペリエンスを提供します。 驚くほど簡単です!検索をyに制限することができます

それで、あなたはここで、Ajaxと呼ばれるこのことについてすべてを学ぶ準備ができています。しかし、それは正確には何ですか? Ajaxという用語は、動的でインタラクティブなWebコンテンツを作成するために使用されるテクノロジーのゆるいグループ化を指します。 Ajaxという用語は、もともとJesse Jによって造られました

この記事シリーズは、2017年半ばに最新の情報と新鮮な例で書き直されました。 このJSONの例では、JSON形式を使用してファイルに単純な値を保存する方法について説明します。 キー価値ペア表記を使用して、あらゆる種類を保存できます

楽なWebページレイアウトのためにjQueryを活用する:8本質的なプラグイン jQueryは、Webページのレイアウトを大幅に簡素化します。 この記事では、プロセスを合理化する8つの強力なjQueryプラグイン、特に手動のウェブサイトの作成に役立ちます

コアポイント これは通常、メソッドを「所有」するオブジェクトを指しますが、関数がどのように呼び出されるかに依存します。 現在のオブジェクトがない場合、これはグローバルオブジェクトを指します。 Webブラウザでは、ウィンドウで表されます。 関数を呼び出すと、これはグローバルオブジェクトを維持しますが、オブジェクトコンストラクターまたはそのメソッドを呼び出すとき、これはオブジェクトのインスタンスを指します。 call()、apply()、bind()などのメソッドを使用して、このコンテキストを変更できます。これらのメソッドは、与えられたこの値とパラメーターを使用して関数を呼び出します。 JavaScriptは優れたプログラミング言語です。数年前、この文はそうでした

jQueryは素晴らしいJavaScriptフレームワークです。ただし、他のライブラリと同様に、何が起こっているのかを発見するためにフードの下に入る必要がある場合があります。おそらく、バグをトレースしているか、jQueryが特定のUIをどのように達成するかに興味があるからです

この投稿は、Android、BlackBerry、およびiPhoneアプリ開発用の有用なチートシート、リファレンスガイド、クイックレシピ、コードスニペットをコンパイルします。 開発者がいないべきではありません! タッチジェスチャーリファレンスガイド(PDF) Desigの貴重なリソース
