検索

JSオブジェクト指向の詳しい入門(2)

Jun 29, 2017 pm 01:37 PM
javascript物体ノート

メニューナビゲーション、「JS オブジェクト指向メモ 1」、参考書籍: Ruan Yifeng の「JavaScript 標準リファレンスチュートリアル」

1. コンストラクターと新しいコマンド

2. このキーワード

3. 構築関数と新しいコマンド

4. コンストラクターと新しいコマンド

5. コンストラクターと新しいコマンド

6. コンストラクターと新しいコマンド

7. コンストラクターと新しいコマンド

8. コンストラクターと新しいコマンド

1. コンストラクターと新しいコマンド

1. コンストラクター

  • JavaScript 言語のオブジェクト システムは、「クラス」ではなく、関数 (コンストラクター) とプロトタイプ チェーン (プロトタイプ) によって構成されます。 )

  • 通常の関数と区別するために、コンストラクター名の最初の文字は通常、次のように大文字で表記されます。コンストラクターの:

    a. this キーワードは、生成されるオブジェクト インスタンスを表す関数本体内で使用されます。
  • b. このコンストラクターは、オブジェクトを生成するときに使用されます。 new コマンドで呼び出す必要があります

2. new this关键字,代表了所要生成的对象实例;
   b、生成对象的时候,必需用new命令调用此构造函数

2、new 

  作用:就是执行构造函数,返回一个实例对象 

var Person = function(name, age){this.name = name;this.age = age;this.email = 'cnblogs@sina.com';this.eat = function(){
        console.log(this.name + ' is eating noodles');
    }
}var per = new Person('王大锤', 18);
console.log(per.name + ', ' + per.age + ', ' + per.email); //王大锤, 18, cnblogs@sina.comper.eat();  //王大锤 is eating noodles

执行new命令时的原理步骤:

  1. 创建一个空对象,作为将要返回的对象实例

  2. 将这个空对象的原型,指向构造函数的prototype属性

  3. 将这个空对象赋值给函数内部的this

    機能: コンストラクターを実行し、インスタンス オブジェクトを返すことです
  4. console.log('---- 返回字符串 start ----');var Person = function(){this.name = '王大锤';return '罗小虎';
    }var per = new Person();for (var item in per){
        console.log( item + ': ' + per[item] );
    }//---- 返回字符串 start ----//name: 王大锤console.log('----- 返回对象 start ----');var PersonTwo = function(){this.name = '倚天剑';return {nickname: '屠龙刀', price: 9999 };
    }var per2 = new PersonTwo();for (var item in per2){
        console.log(item + ': ' + per2[item]);
    }//----- 返回对象 start ----//nickname: 屠龙刀//price: 9999

    新しいコマンドを実行するときの基本的な手順:
    1. 返されるオブジェクト インスタンスとして空のオブジェクトを作成します

      この空のオブジェクトのプロトタイプを プロトタイプ 属性の
      この空のオブジェクトを関数内の this キーワードに割り当てます

      Start コンストラクター内のコードを実行します

      注: コンストラクターに return キーワードがある場合、戻り値が非オブジェクトの場合、新しいコマンドは返された情報を無視し、最終的な戻り値は this になります。構築後のオブジェクト;

      return returns がこれと何の関係もない新しいオブジェクトである場合、最後の new コマンドはこのオブジェクトの代わりに新しいオブジェクトを返します。サンプルコード:

      var Person = function(){ 
          console.log( this == window );  //truethis.price = 5188; 
      }var per = Person();
      console.log(price); //5188console.log(per);  //undefinedconsole.log('......_-_'); //......_-_console.log(per.price); //Uncaught TypeError: Cannot read property 'helloPrice' of undefined
      コードを見る

      コンストラクターを呼び出すときに new キーワードを使用するのを忘れた場合、コンストラクター内のこれがグローバル オブジェクト ウィンドウになり、プロパティもグローバル プロパティになります。

      コンストラクターによって割り当てられた変数はオブジェクトではなくなりましたが、JS では未定義の変数に属性を追加することができないため、未定義の属性を呼び出すとエラーが報告されます。 例:
      var Person = function(){ 'use strict';
          console.log( this );  //undefinedthis.price = 5188; //Uncaught TypeError: Cannot set property 'helloPrice' of undefined}var per = Person();
      🎜🎜コードを表示🎜🎜🎜 新しいキーワードを忘れないようにするには、関数内の最初の行に「use strict」を追加するという解決策があります。🎜🎜関数の使用を示します。厳密モードでは、関数内の this はグローバル オブジェクト ウィンドウを指すことができず、デフォルトは未定義であるため、呼び出しが追加されないとエラーが報告されます 🎜🎜🎜🎜🎜
      var Person = function(){ //先判断this是否为Person的实例对象,不是就new一个if (!(this instanceof Person)){return new Person();
          }
          console.log( this );  //Person {}this.price = 5188; 
      }var per = Person(); 
      console.log(per.price); //5188
      🎜🎜コードを表示🎜🎜

      另外一种解决方式,就是在函数内部手动添加new命令:

      var Person = function(){ //先判断this是否为Person的实例对象,不是就new一个if (!(this instanceof Person)){return new Person();
          }
          console.log( this );  //Person {}this.price = 5188; 
      }var per = Person(); 
      console.log(per.price); //5188
      View Code

       

       

      二、this关键字

      var Person = function(){
          console.log('1111'); 
          console.log(this); this.name = '王大锤';this.age = 18;this.run = function(){
              console.log('this is Person的实例对象吗:' + (this instanceof Person) ); 
              console.log(this); 
          }
      }var per = new Person();
      per.run();/* 打印日志:
      1111
      Person {}
      this is Person的实例对象吗:true
      Person {name: "王大锤", age: 18, run: function}*/console.log('---------------');var Employ = {
          email: 'cnblogs@sina.com',
          name: '赵日天',
          eat: function(){
              console.log(this);
          }
      }
      
      console.log(Employ.email + ', ' + Employ.name);
      Employ.eat();/* 打印日志:
      ---------------
      cnblogs@sina.com, 赵日天
      Object {email: "cnblogs@sina.com", name: "赵日天", eat: function}*/
      View Code

      1、this总是返回一个对象,返回属性或方法当前所在的对象, 如上示例代码

      2、对象的属性可以赋值给另一个对象,即属性所在的当前对象可变化,this的指向可变化

      var A = { 
          name: '王大锤', 
          getInfo: function(){return '姓名:' + this.name;
          } 
      }var B = { name: '赵日天' };
      
      B.getInfo = A.getInfo;
      console.log( B.getInfo() ); //姓名:赵日天//A.getInfo属性赋给B, 于是B.getInfo就表示getInfo方法所在的当前对象是B, 所以这时的this.name就指向B.name
      View Code

       3、由于this指向的可变化性,在层级比较多的函数中需要注意使用this。一般来说,在多层函数中需要使用this时,设置一个变量来固定this的值,然后在内层函数中这个变量。

      示例1:多层中的this

      //1、多层中的this (错误演示)var o = {
          f1: function(){
              console.log(this); //这个this指的是o对象var f2 = function(){
                  console.log(this);
              }();//由于写法是(function(){ })() 格式, 则f2中的this指的是顶层对象window    }
      }
      
      o.f1();/* 打印日志:
      Object {f1: function}
      
      Window {stop: function, open: function, alert: function, confirm: function, prompt: function…}*///2、上面代码的另一种写法(相同效果)var temp = function(){
          console.log(this);
      }var o = {
          f1: function(){
              console.log(this); //这个this指o对象var f2 = temp(); //temp()中的this指向顶层对象window    }
      }
      o.f1(); 
      /* 打印日志
      Object {f1: function}
      
      Window {stop: function, open: function, alert: function, confirm: function, prompt: function…}*///表示上面两种写法是一样的效果,this的错误演示//3、多层中this的正确使用:使用一个变量来固定this对象,然后在内层中调用该变量var o = {
          f1: function(){
              console.log(this); //o对象var that = this;var f2 = function(){
                  console.log(that); //这个that指向o对象        }();
          }
      }
      o.f1();/* 打印日志:
      Object {f1: function}
      Object {f1: function}*/
      View Code

      示例2: 数组遍历中的this

      //1、多层中数组遍历中this的使用 (错误演示)var obj = {
          email: '大锤@sina.com', 
          arr: ['aaa', 'bbb', '333'],
          fun: function(){//第一个this指的是obj对象this.arr.forEach(function(item){//这个this指的是顶层对象window, 由于window没有email变量,则为undefinedconsole.log(this.email + ': ' + item);
              });
          }
      }
      
      obj.fun(); 
      /* 打印结果:
      undefined: aaa
      undefined: bbb
      undefined: 333 *///2、多层中数组遍历中this的使用 (正确演示,第一种写法)var obj = {
          email: '大锤@sina.com', 
          arr: ['aaa', 'bbb', '333'],
          fun: function(){//第一个this指的是obj对象var that = this; //将this用变量固定下来this.arr.forEach(function(item){//这个that指的是对象objconsole.log(that.email + ': ' + item);
              });
          }
      }
      obj.fun(); //调用/* 打印日志:
      大锤@sina.com: aaa
      大锤@sina.com: bbb
      大锤@sina.com: 333 *///3、多层中数组遍历中this正确使用第二种写法:将this作为forEach方法的第二个参数,固定循环中的运行环境var obj = {
          email: '大锤@sina.com', 
          arr: ['aaa', 'bbb', '333'],
          fun: function(){//第一个this指的是obj对象this.arr.forEach(function(item){//这个this从来自参数this, 指向obj对象console.log(this.email + ': ' + item);
              }, this);
          }
      }
      obj.fun(); //调用/* 打印日志:
      大锤@sina.com: aaa
      大锤@sina.com: bbb
      大锤@sina.com: 333 */
      View Code

       

      4、关于js提供的call、apply、bind方法对this的固定和切换的用法

        1)、function.prototype.call(): 函数实例的call方法,可以指定函数内部this的指向(即函数执行时所在的作用域),然后在所指定的作用域中,调用该函数。
        如果call(args)里面的参数不传,或者为null、undefined、window, 则默认传入全局顶级对象window;
        如果call里面的参数传入自定义对象obj, 则函数内部的this指向自定义对象obj, 在obj作用域中运行该函数

      var obj = {};var f = function(){
          console.log(this);return this;
      }
      
      console.log('....start.....');
      f();
      f.call();
      f.call(null);
      f.call(undefined);
      f.call(window);
      console.log('**** call方法的参数如果为空、null和undefined, 则默认传入全局等级window;如果call方法传入自定义对象obj,则函数f会在对象obj的作用域中运行 ****');
      f.call(obj);
      console.log('.....end.....');/* 打印日志:
      ....start.....
      Window {stop: function, open: function, alert: function, confirm: function, prompt: function…}
      Window {stop: function, open: function, alert: function, confirm: function, prompt: function…}
      Window {stop: function, open: function, alert: function, confirm: function, prompt: function…}
      Window {stop: function, open: function, alert: function, confirm: function, prompt: function…}
      Window {stop: function, open: function, alert: function, confirm: function, prompt: function…}
      **** call方法的参数如果为空、null和undefined, 则默认传入全局等级window;如果call方法传入自定义对象obj,则函数f会在对象obj的作用域中运行 ****
      Object {}
      .....end.....*/
      View Code

       

    以上がJSオブジェクト指向の詳しい入門(2)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

    Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

    Python vs. JavaScript:コミュニティ、ライブラリ、リソースPython vs. JavaScript:コミュニティ、ライブラリ、リソースApr 15, 2025 am 12:16 AM

    PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

    C/CからJavaScriptへ:すべてがどのように機能するかC/CからJavaScriptへ:すべてがどのように機能するかApr 14, 2025 am 12:05 AM

    C/CからJavaScriptへのシフトには、動的なタイピング、ゴミ収集、非同期プログラミングへの適応が必要です。 1)C/Cは、手動メモリ管理を必要とする静的に型付けられた言語であり、JavaScriptは動的に型付けされ、ごみ収集が自動的に処理されます。 2)C/Cはマシンコードにコンパイルする必要がありますが、JavaScriptは解釈言語です。 3)JavaScriptは、閉鎖、プロトタイプチェーン、約束などの概念を導入します。これにより、柔軟性と非同期プログラミング機能が向上します。

    JavaScriptエンジン:実装の比較JavaScriptエンジン:実装の比較Apr 13, 2025 am 12:05 AM

    さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

    ブラウザを超えて:現実世界のJavaScriptブラウザを超えて:現実世界のJavaScriptApr 12, 2025 am 12:06 AM

    現実世界におけるJavaScriptのアプリケーションには、サーバー側のプログラミング、モバイルアプリケーション開発、モノのインターネット制御が含まれます。 2。モバイルアプリケーションの開発は、ReactNativeを通じて実行され、クロスプラットフォームの展開をサポートします。 3.ハードウェアの相互作用に適したJohnny-Fiveライブラリを介したIoTデバイス制御に使用されます。

    next.jsを使用してマルチテナントSaaSアプリケーションを構築する(バックエンド統合)next.jsを使用してマルチテナントSaaSアプリケーションを構築する(バックエンド統合)Apr 11, 2025 am 08:23 AM

    私はあなたの日常的な技術ツールを使用して機能的なマルチテナントSaaSアプリケーション(EDTECHアプリ)を作成しましたが、あなたは同じことをすることができます。 まず、マルチテナントSaaSアプリケーションとは何ですか? マルチテナントSaaSアプリケーションを使用すると、Singの複数の顧客にサービスを提供できます

    next.jsを使用してマルチテナントSaaSアプリケーションを構築する方法(フロントエンド統合)next.jsを使用してマルチテナントSaaSアプリケーションを構築する方法(フロントエンド統合)Apr 11, 2025 am 08:22 AM

    この記事では、許可によって保護されたバックエンドとのフロントエンド統合を示し、next.jsを使用して機能的なedtech SaaSアプリケーションを構築します。 FrontEndはユーザーのアクセス許可を取得してUIの可視性を制御し、APIリクエストがロールベースに付着することを保証します

    JavaScript:Web言語の汎用性の調査JavaScript:Web言語の汎用性の調査Apr 11, 2025 am 12:01 AM

    JavaScriptは、現代のWeb開発のコア言語であり、その多様性と柔軟性に広く使用されています。 1)フロントエンド開発:DOM操作と最新のフレームワーク(React、Vue.JS、Angularなど)を通じて、動的なWebページとシングルページアプリケーションを構築します。 2)サーバー側の開発:node.jsは、非ブロッキングI/Oモデルを使用して、高い並行性とリアルタイムアプリケーションを処理します。 3)モバイルおよびデスクトップアプリケーション開発:クロスプラットフォーム開発は、反応および電子を通じて実現され、開発効率を向上させます。

    See all articles

    ホットAIツール

    Undresser.AI Undress

    Undresser.AI Undress

    リアルなヌード写真を作成する AI 搭載アプリ

    AI Clothes Remover

    AI Clothes Remover

    写真から衣服を削除するオンライン AI ツール。

    Undress AI Tool

    Undress AI Tool

    脱衣画像を無料で

    Clothoff.io

    Clothoff.io

    AI衣類リムーバー

    AI Hentai Generator

    AI Hentai Generator

    AIヘンタイを無料で生成します。

    ホットツール

    ZendStudio 13.5.1 Mac

    ZendStudio 13.5.1 Mac

    強力な PHP 統合開発環境

    PhpStorm Mac バージョン

    PhpStorm Mac バージョン

    最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール

    VSCode Windows 64 ビットのダウンロード

    VSCode Windows 64 ビットのダウンロード

    Microsoft によって発売された無料で強力な IDE エディター

    Dreamweaver Mac版

    Dreamweaver Mac版

    ビジュアル Web 開発ツール