ホームページ  >  記事  >  ウェブフロントエンド  >  JavaScript オブジェクト指向とこのポインティング (コード付き)

JavaScript オブジェクト指向とこのポインティング (コード付き)

php中世界最好的语言
php中世界最好的语言オリジナル
2018-04-17 14:27:411543ブラウズ

今回は JavaScript のオブジェクト指向とこのポインティング (コード付き) をお届けします。 JavaScript を使用する際の 注意事項 オブジェクト指向とこのポインティングについては、次のような実際的なケースを見てみましょう。

私たちのプログラミング言語は、「マシン指向」から「プロセス指向」、そして「オブジェクト指向」へのプロセスを経てきました。 JavaScript は、プロセス指向とオブジェクト指向の中間のオブジェクトベースの言語です。 JavaScript を学習するプロセスにおいて、OOP は非常に重要な部分です。JS におけるオブジェクト指向のアプローチについて説明しましょう。 ! !

1. OOP の基本的な問題

1.1 プロセス指向とオブジェクト指向とは何ですか?

プロセス指向: 問題を解決する方法のプロセスステップに焦点を当てます。プログラミングの特徴は、クラスやオブジェクトの概念を持たず、処理の各ステップを一つ一つ関数で実装することです。

オブジェクト指向: どのオブジェクトが問題を解決するかに焦点を当てます。プログラミングの特徴は、クラスが次々と現れ、そのクラスからオブジェクトを取得して特定の問題を解決することです。

呼び出し元にとって、プロセス指向では、呼び出し元がさまざまな機能を自分で実装する必要があります。一方、オブジェクト指向では、呼び出し元がメソッドの実装の詳細を理解する必要がなく、オブジェクト内の特定のメソッドの機能を呼び出し元に伝えるだけで済みます。

1.2 オブジェクト指向の 3 つの主要な特徴

継承、カプセル化、ポリモーフィズム

1.3 クラスとオブジェクトの関係

①クラス:同じ性質(プロパティ)と動作(メソッド)を持つクラスの集合。

例:人間→属性:身長、体重、性別方法:食べる、話す、歩く

②オブジェクト:クラスの中から、ある属性値やメソッドを持つ個体を取り出します。

例: 張三 --> 属性: 身長 180、体重 180 方法: 会話 --> 私の名前は張三、身長 180 です

③クラスとオブジェクトの関係

クラスは抽象であり、オブジェクトは具象です (クラスはオブジェクトの抽象化であり、オブジェクトはクラスの具象化です)

説明:

クラスは抽象概念です。クラスには

プロパティとメソッドがあるとしか言えませんが、プロパティに特定の値を割り当てることはできません。たとえば、人間には名前がありますが、その名前が何であるかを言うことはできません。 。 。

オブジェクトは特定のインスタンス、つまりクラス内の属性に特定の値を割り当てる個体です。たとえば、張三が一人の人間である場合、張三の名前は張三であると言えます。つまり、張三は人間の各属性に特定の割り当てを行っているため、張三は人間によって生成されたオブジェクトです。

2. JavaScript のオブジェクト指向

2.1 クラスとオブジェクトを作成する手順

①クラス(

コンストラクター)を作成します。クラス名はビッグキャメルケースルールを使用する必要があります。つまり、各単語の最初の文字を大文字にする必要があります。 りー

② クラスを通じてオブジェクトをインスタンス化(新規)します。

var obj = 新しいクラス名 (属性 1 の特定の値);

obj.property; プロパティを呼び出します

obj.method(); メソッドを呼び出す

③注意事項

>>>クラス名を使用してオブジェクトを新規作成するプロセスを「クラスのインスタンス化」といいます

>>>クラス内のこれは、インスタンス化されたときに新しく作成されたオブジェクトを指します。したがって、this.property と this.method は実際に、新しく作成されるオブジェクトにプロパティとメソッドをバインドします。

>>>クラスで独自のプロパティを呼び出すには、this.property 名を使用する必要があります。変数名を直接使用すると、対応するプロパティにアクセスできません。

>>>クラス名はキャメルケースルールを使用し、通常の関数との違いに注意してください。

2.2 2つの重要な属性コンストラクターとinstanceof

①constructor:返回当前对象的构造函数

>>>zhangsan.constructor = Person; √

②instanceof:检测一个对象,是不是一个类的实例;

>>>lisi instanceof Person √ lisi是通过Person类new出的

>>>lisi instanceof Object √ 所有对象都是Object的实例

>>>Person instanceof Object √ 函数本身也是对象

3、 JavaScript中的this指向问题

在上一部分中,我们创建了一个类,并通过这个类new出了一个对象。 但是,这里面出现了大量的this。 很多同学就要懵逼了,this不是“这个”的意思吗?为什么我在函数里面写的this定义的属性,最后到了函数new出的对象呢??

3.1谁最终调用函数,this就指向谁!

① this指向谁,不应该考虑函数在哪声明,而应该考虑函数在哪调用!!

② this指向的,永远只可能是对象,不可能是函数!!

③ this指向的对象,叫做函数的上下文context,也叫函数的调用者。

3.2this指向的规律(与函数的调用方式息息相关!)

① 通过函数名()调用的,this永远指向window

func(); // this--->window
//【解释】 我们直接用一个函数名()调用,函数里面的this,永远指向window。

② 通过对象.方法调用的,this指向这个对象

// 狭义对象
 var obj = {
  name:"obj",
  func1 :func
 };
 obj.func1(); // this--->obj
//【解释】我们将func函数名,当做了obj这个对象的一个方法,然后使用对象名.方法名, 这时候函数里面的this指向这个obj对象。
 // 广义对象
 document.getElementById("p").onclick = function(){
  this.style.backgroundColor = "red";
}; // this--->p
//【解释】对象打点调用还有一个情况,我们使用getElementById取到一个p控件,也是一种广义的对象,用它打点调用函数,则函数中的this指向这个p对象。

③ 函数作为数组的一个元素,用数组下标调用,this指向这个数组

var arr = [func,1,2,3];
arr[0](); // this--->arr
//【解释】这个,我们把函数名,当做数组中的一个元素。使用数组下标调用,则函数中的this将指向这个数组arr。

④ 函数作为window内置函数的回调函数使用,this指向window。比如setTimeout、setInterval等

setTimeout(func,1000);// this--->window
//setInterval(func,1000);
//【解释】使用setTimeout、setInterval等window内置函数调用函数,则函数中的this指向window。

⑤ 函数作为构造函数,使用new关键字调用,this指向新new出的对象

var obj = new func(); //this--->new出的新obj
//【解释】这个就是第二部分我们使用构造函数new对象的语句,将函数用new关键字调用,则函数中的this指向新new出的对象。

3.3关于this问题的面试题

var fullname = 'John Doe';
var obj = {
  fullname: 'Colin Ihrig',
  prop: {
    fullname: 'Aurelio De Rosa',
    getFullname: function() {
      return this.fullname;
    }
  }
};
console.log(obj.prop.getFullname()); 
// 函数的最终调用者 obj.prop 
   
var test = obj.prop.getFullname;
console.log(test()); 
// 函数的最终调用者 test() this-> window
   
obj.func = obj.prop.getFullname;
console.log(obj.func()); 
// 函数最终调用者是obj
   
var arr = [obj.prop.getFullname,1,2];
arr.fullname = "JiangHao";
console.log(arr[0]());
// 函数最终调用者数组

好了,这篇博客,我们了解了什么是面向对象、类和对象的关系、JS中声明类与对象的步骤,以及重点讲解的this指向问题! 希望能够帮助大家真正的理解了this的认知,下面我会继续给大家分享关于面向对象方面的问题。多谢大家的支持!!!

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

Vue中computed属性的使用方法

ajax与跨域jsonp


以上がJavaScript オブジェクト指向とこのポインティング (コード付き)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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