高度なJS関連の知識

一个新手
一个新手オリジナル
2017-10-19 09:16:361472ブラウズ

継承: 他のオブジェクトは現在のオブジェクトにはない属性とメソッドを持ち、それらを自分用に使用します。これが継承です

1 混合継承


var I={ };    
var obj = {
                name: 'jack',
                age:18,
                sayGoodbye : function () {
                                        console.log("goodbye") ;
                }
    }// 混入式继承, a中 将继承obj的所有属性
    for (var k in obj ) {
        a[k] = obj [k] ;
    }

2. プロトタイプの継承

  1. プロトタイプは他の人も使用できます 関連オブジェクトはこの機能を共有し、継承を実現できます

  2. 実装手順

a) プロトタイプオブジェクトに(オブジェクトの動的特性を通じて)新しいメンバーを追加することは、厳密な意味での継承ではありません、、、、インスタンスオブジェクトはPrototypeを継承します

b) プロトタイプオブジェクトを直接置き換えます


    1. Constructor.prototypr = new object

    2. インスタンスオブジェクトはプロトタイプ(新しいオブジェクト)を継承します

    3. オブジェクトが元々属性とメソッドを持っている場合、置換メソッドを使用すると元のプロパティとメソッドが上書きされます


  1. オブジェクトとメソッド、代入valueを別のオブジェクトにfor...in...
    1. 3. 古典的な継承
js

var object 1 = Object.creat(object 2);

この時、作成されたObject 1はObjectを継承します。 2

Object.creat メソッドには互換性の問題があります

解決策:

1. ブラウザが Object.create メソッドをサポートしているかどうかを確認し、サポートしていない場合は、手動で create メソッドをオブジェクトに直接追加します

2. 関数内で関数をカスタマイズします。ブラウザが Object.create メソッドをサポートしているかどうかを判断し、サポートしていない場合は、直接オブジェクトを呼び出します。オブジェクト、すべてのオブジェクトにはコンストラクターがあり、各コンストラクターのプロトタイプ オブジェクトはオブジェクトであり、コンストラクターがあります

その後、チェーン構造が形成され、それをプロトタイプ チェーンと呼びます


プロトタイプ継承とは何ですか?

プロトタイプチェーンの構造を変更することで、継承を実現する方法がプロトタイプ継承です

属性検索の原則


オブジェクトのメンバーにアクセスするときは、まず自分の中でそれを探します


If 見つからない場合は、現在のオブジェクトのプロトタイプ オブジェクトに移動して見つけます。存在する場合は、


を使用して、プロトタイプ オブジェクトのプロトタイプ オブジェクトに移動して見つけます。存在する場合は、


を使用してオブジェクトをガイドします。まだ存在しない場合は、nullを返します

    プロトタイプチェーンの継承構造を変更することによって実現される継承は、プロトタイプ継承と呼ばれます
  1. function creat(obj) {    
        if (object.creat){            
        return Object.creat(obj);
           }else{
                function F(){
                    }
                F.prototype = obj;            
                return new F();
                }
        }

    p オブジェクトに含まれるオブジェクトは次のとおりです: Person.prototype 内のメンバーであり、それ自体が所有しています

  2. person.prototype のメンバーは次のとおりです: Object.prototype のメンバーとそれ自体のメンバー
  3. Object.prototype のメンバー:

  4. コンストラクター: プロトタイプに関連するコンストラクターへのポインタ
  5. HasOwnPropertyメソッド: エクスクルーシブそのものがある属性を持っているかどうかを判定する

  6. properIsEnumerableメソッド: 1. 属性がオブジェクト自体に属しているかどうかを判定、2. 属性がトラバース可能かどうかを判定

toString toLocalString: オブジェクトを文字列に変換する toLocalString を文字列に変換するときに適用されるローカル設定モード

valueOf メソッド: オブジェクトが操作に参加するとき、最初に valueOf メソッドを呼び出してオブジェクトの値を取得します。値は操作に参加できません。toString メソッドを使用して調整されます
__proto__ 属性: 現在のオブジェクトのプロトタイプ オブジェクトを指します

関数

関数を作成する 3 つの方法:

直接宣言

関数式

new function()function関数を使用して関数を作成できます:

構文:

rrereerreerreerreee

eval

JSON 形式の文字列を解析するには、{} がコード セグメント

1 に解析されることに注意してください。「JSON 形式の文字列 name="

eval("var 変数名 =」の前に「var 変数」を結合できます。 + JSON 形式の文字列);

2. JSON 形式の文字列の前後に () を結合できます

eval("("+JSON 形式の文字列+" )")

静的メンバーとインスタンス メンバー

静的メンバー

コンストラクターを通じてアクセスされるプロパティとメソッドは静的メンバーです

インスタンスメンバー

オブジェクト (インスタンス) を通じてアクセスされるプロパティとメソッドはインスタンスメンバーです

以上が高度なJS関連の知識の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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