ホームページ ウェブフロントエンド jsチュートリアル JSオブジェクト指向の詳しい入門(2)

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 までご連絡ください。

    ホット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ヘンタイを無料で生成します。

    ホットツール

    メモ帳++7.3.1

    メモ帳++7.3.1

    使いやすく無料のコードエディター

    SublimeText3 中国語版

    SublimeText3 中国語版

    中国語版、とても使いやすい

    ゼンドスタジオ 13.0.1

    ゼンドスタジオ 13.0.1

    強力な PHP 統合開発環境

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール

    SublimeText3 Mac版

    SublimeText3 Mac版

    神レベルのコード編集ソフト(SublimeText3)

    小紅書メモを削除する方法 小紅書メモを削除する方法 Mar 21, 2024 pm 08:12 PM

    小紅書メモを削除するにはどうすればよいですか? メモは小紅書アプリで編集できます。ほとんどのユーザーは小紅書メモの削除方法を知りません。次に、エディターがユーザーに小紅書メモの削除方法に関する写真とテキストを提供します。チュートリアル、興味のあるユーザーが来て、それを受講してください見てください!小紅書使い方チュートリアル 小紅書メモの削除方法 1. まず小紅書アプリを開いてメインページに入り、右下隅の[自分]を選択して特別エリアに入ります; 2. 次に、マイエリアで、表示されているメモページをクリックします下の図で、削除したいメモを選択します; 3. メモページに入り、右上隅の [3 つの点] をクリックします; 4. 最後に、下部に機能バーが展開され、[削除] をクリックして完了します。

    小紅書に投稿したメモが見つからない場合はどうすればよいですか?送信したばかりのメモが見つからない理由は何ですか? 小紅書に投稿したメモが見つからない場合はどうすればよいですか?送信したばかりのメモが見つからない理由は何ですか? Mar 21, 2024 pm 09:30 PM

    小紅書のユーザーとして、私たちは皆、公開されたノートが突然消えてしまう状況に遭遇したことがありますが、間違いなく混乱し、心配しています。この場合、どうすればよいでしょうか?この記事では、「小紅書が公開したメモが見つからない場合の対処方法」というテーマに焦点を当て、詳細な回答を提供します。 1. 小紅書が発行したメモが紛失した場合はどうすればよいですか?まず、パニックにならないでください。メモがなくなっていることに気づいた場合は、パニックに陥らず、落ち着いて行動することが重要です。これは、プラットフォームのシステム障害または操作エラーが原因である可能性があります。リリース記録の確認も簡単です。小紅書アプリを開き、「自分」→「公開」→「すべての出版物」をクリックするだけで、自分の出版記録を表示できます。ここでは、以前に公開されたノートを簡単に見つけることができます。 3.再投稿。見つかったら

    小紅書でノートに商品リンクを追加する方法 小紅書でノートに商品リンクを追加するチュートリアル 小紅書でノートに商品リンクを追加する方法 小紅書でノートに商品リンクを追加するチュートリアル Mar 12, 2024 am 10:40 AM

    小紅書でメモに商品リンクを追加するにはどうすればよいですか?小紅書アプリでは、ユーザーはさまざまなコンテンツを閲覧できるだけでなく、ショッピングもできるため、このアプリにはショッピングのおすすめや良い商品の共有に関するコンテンツがたくさんあります。このアプリでは、ショッピング体験を共有したり、協力してくれる販売者を見つけたり、メモにリンクを追加したりすることもできます。便利なだけでなく、専門家がいくつかの機能を備えているため、多くの人がこのアプリをショッピングに使用したいと考えています。興味深いコンテンツを閲覧して、自分に合った衣料品があるかどうかを確認できます。ノートに商品リンクを追加する方法を見てみましょう! 小紅書ノートに商品リンクを追加する方法 携帯電話のデスクトップでアプリを開きます。アプリのホームページをクリックします

    WebSocket と JavaScript: リアルタイム監視システムを実装するための主要テクノロジー WebSocket と JavaScript: リアルタイム監視システムを実装するための主要テクノロジー Dec 17, 2023 pm 05:30 PM

    WebSocketとJavaScript:リアルタイム監視システムを実現するためのキーテクノロジー はじめに: インターネット技術の急速な発展に伴い、リアルタイム監視システムは様々な分野で広く利用されています。リアルタイム監視を実現するための重要なテクノロジーの 1 つは、WebSocket と JavaScript の組み合わせです。この記事では、リアルタイム監視システムにおける WebSocket と JavaScript のアプリケーションを紹介し、コード例を示し、その実装原理を詳しく説明します。 1.WebSocketテクノロジー

    MySQLクエリ結果の配列をオブジェクトに変換するにはどうすればよいですか? MySQLクエリ結果の配列をオブジェクトに変換するにはどうすればよいですか? Apr 29, 2024 pm 01:09 PM

    MySQL クエリ結果の配列をオブジェクトに変換する方法は次のとおりです。 空のオブジェクト配列を作成します。結果の配列をループし、行ごとに新しいオブジェクトを作成します。 foreach ループを使用して、各行のキーと値のペアを新しいオブジェクトの対応するプロパティに割り当てます。新しいオブジェクトをオブジェクト配列に追加します。データベース接続を閉じます。

    JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 Dec 17, 2023 pm 05:13 PM

    JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 はじめに: 今日、天気予報の精度は日常生活と意思決定にとって非常に重要です。テクノロジーの発展に伴い、リアルタイムで気象データを取得することで、より正確で信頼性の高い天気予報を提供できるようになりました。この記事では、JavaScript と WebSocket テクノロジを使用して効率的なリアルタイム天気予報システムを構築する方法を学びます。この記事では、具体的なコード例を通じて実装プロセスを説明します。私たちは

    簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 Jan 05, 2024 pm 06:08 PM

    JavaScript チュートリアル: HTTP ステータス コードを取得する方法、特定のコード例が必要です 序文: Web 開発では、サーバーとのデータ対話が頻繁に発生します。サーバーと通信するとき、多くの場合、返された HTTP ステータス コードを取得して操作が成功したかどうかを判断し、さまざまなステータス コードに基づいて対応する処理を実行する必要があります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法を説明し、いくつかの実用的なコード例を示します。 XMLHttpRequestの使用

    小紅書でメモのチュートリアルを公開するにはどうすればよいですか?メモを投稿することでユーザーをブロックできますか? 小紅書でメモのチュートリアルを公開するにはどうすればよいですか?メモを投稿することでユーザーをブロックできますか? Mar 25, 2024 pm 03:20 PM

    小紅書はライフスタイル共有プラットフォームとして、食、旅行、美容などさまざまな分野のメモをカバーしています。多くのユーザーは小紅書でメモを共有したいと思っていますが、その方法がわかりません。この記事では、Xiaohongshu にメモを投稿するプロセスを詳しく説明し、プラットフォーム上で特定のユーザーをブロックする方法を検討します。 1.小紅書でメモのチュートリアルを公開するにはどうすればよいですか? 1. 登録とログイン: まず、携帯電話に小紅書アプリをダウンロードし、登録とログインを完了する必要があります。パーソナルセンターに個人情報を記入することは非常に重要です。アバターをアップロードし、ニックネームや自己紹介を記入することで、他のユーザーがあなたの情報を理解しやすくなり、メモに注意を向けやすくなります。 3. 公開チャネルを選択します。ホームページの下部にある [メモを送信] ボタンをクリックし、公開するチャネルを選択します。

    See all articles