ホームページ  >  記事  >  ウェブフロントエンド  >  JS におけるこの値の 4 つのモード

JS におけるこの値の 4 つのモード

小云云
小云云オリジナル
2018-02-24 14:22:341510ブラウズ


この記事は主に JS のこの値の 4 つのモードをと共有し、皆様のお役に立つことを願っています。

1. 関数の紹介

JavaScript の各関数内には、Ming の宣言時に定義された仮パラメータに加えて、各関数には次の 2 つの追加パラメータもあります: <code><span style="font-size: 14px;">this</span><span style="font-size: 14px;">arguments</span>

参数<span style="font-size: 14px;">arguments</span>是一个数组类型的变量,数组中的值就是实际调用函数时传进来的参数列表。在定义函数时会有函数的形式参数<span style="font-size: 14px;">parameters</span>,在具体调用函数时,当实际参数<span style="font-size: 14px;">arguments</span>的个数与形式参数<span style="font-size: 14px;">parameters</span>的个数不匹配时,不会导致运行时错误。如果实际参数过多,超出的参数值会被忽略掉。如果实际参数值过少,缺少的值会被替换为<span style="font-size: 14px;">undefined</span>。函数执行时不会对参数值进行类型校验,也就是说任何类型的值都可以传递给任何参数。

参数 <span style="font-size: 14px;">this</span>在面向对象编程语言中是非常重要的概念,它是指具体的类对象的实例,也就是类<span style="font-size: 14px;">new</span>出来的那个具体的对象本身。但是在JavaScript中的<span style="font-size: 14px;">this</span>的值取决于调用的模式。在JavaScript中一共有四种调用模式:方法调用模式、函数调用模式、构造器调用模式和apply调用模式。

二、方法调用模式

当一个函数被定义在一个对象的属性上,这时我们称这个函数是这个对象的一个方法。当这个方法被调用时,这个函数内部的this指向的就是该对象,示例如下:

<span style="font-size: 14px;">var obj = {    value: 1,<br/>    add: function() {        // 这里的 this 是绑定在 obj 这个对象上的<br/>        this.value += 1;        return this.value;<br/>    }<br/>};<br/>console.info(obj.add()); // 2console.info(obj.add()); // 3<br/></span>

<span style="font-size: 14px;">obj.add</span>方法可以通过<span style="font-size: 14px;">this</span>访问自己所属对象<span style="font-size: 14px;">obj</span>,所以它能从对象中取值或对对象进行修改。this到对象的绑定发生在方法被调用的时候。 通过<span style="font-size: 14px;">this</span>可取得它们所属对象的上下文的方法称为公共方法。

三、函数调用模式

当一个函数并非一个对象的属性时,那么它就是被当做一个函数来调用的。

例一

<span style="font-size: 14px;">var a = 1;var add = function(b) {<br/>  // 这里的 this 是绑定在全局作用于 window 上的<br/>  return this.a + b;<br/>};<br/>console.info(add(2)); // 3<br/></span>

例二

<span style="font-size: 14px;">var a = 1;var obj = {<br/>  a: 2,<br/>  add: function(b) {<br/><br/>    var innerAdd = function(innerB) {<br/>      // 这里的 this 绑定的还是 window 对象上的 this<br/>      return this.a + innerB;<br/>    };<br/>    console.info(innerAdd(0)); // 1<br/>    // 这里的 this 是绑定在 obj 对象上的<br/>    return this.a + b;<br/>  }<br/>};<br/>console.info(obj.add(0)); // 2<br/></span>

以上两例可以看出,以此模式调用函数时,this被绑定到了全局对象上。如果依照方法调用模式推理的话,这里的this应该被绑定到外部函数上,但是这个设计缺陷也不是无法解决的,我们可以将外部函数的this赋值给一个变量。如下示例:

例三

<span style="font-size: 14px;">var a = 1;var obj = {<br/>  a: 2,<br/>  add: function(b) {<br/>    // 将绑定在 obj 对象上的 this 赋值给变量 that<br/>    var that = this;    var innerAdd = function(innerB) {<br/>      // 这里调用的是变量 that,这个 that 是绑定在 obj 对象上的<br/>      return that.a + innerB;<br/>    };<br/>    console.info(innerAdd(0)); // 2<br/>    // 这里的 this 是绑定在 obj 对象上的<br/>    return this.a + b;<br/>  }<br/>};<br/>console.info(obj.add(0)); // 2<br/></span>

四、构造器调用模式

如果在一个函数前带上<span style="font-size: 14px;">new</span>来调用,那么内部会创建一个连接到该函数的<span style="font-size: 14px;">prototype</span>this

🎜引数🎜🎜。 🎜🎜🎜🎜Parameters🎜🎜arguments🎜🎜は配列型変数であり、配列内の値は実際に関数が呼び出されるときに渡されるパラメータリストです。関数を定義する場合、関数の仮パラメータ 🎜🎜parameters🎜🎜 が存在します。具体的に関数を呼び出す場合、実際のパラメータの数は 🎜🎜arguments🎜🎜 になります。と仮パラメータ🎜🎜parameters🎜🎜の数が一致しない場合、実行時エラーは発生しません。実パラメータが多すぎる場合、超過したパラメータ値は無視されます。実際のパラメータ値が少なすぎる場合、欠落している値は 🎜🎜unknown🎜🎜 に置き換えられます。関数の実行時にパラメーター値の型チェックは行われません。つまり、任意の型の値を任意のパラメーターに渡すことができます。 🎜🎜🎜🎜パラメータ🎜🎜this🎜🎜は、オブジェクト指向プログラミング言語において非常に重要な概念です。これは、特定のクラスオブジェクトのインスタンス、つまりクラス🎜🎜newを指します。 🎜🎜特定のオブジェクト自体。ただし、JavaScript の 🎜🎜this🎜🎜 の値は呼び出しモードによって異なります。 JavaScript には、メソッド呼び出しモード、関数呼び出しモード、コンストラクター呼び出しモード、および適用呼び出しモードの 4 つの呼び出しモードがあります。 🎜🎜🎜🎜 2. メソッド呼び出しモード 🎜🎜🎜🎜 オブジェクトの属性に対して関数が定義されている場合、その関数をオブジェクトのメソッドと呼びます。このメソッドが呼び出されるとき、関数内の this はオブジェクトを指します。例は次のとおりです: 🎜🎜
<span style="font-size: 14px;">// 定义一个 Person 函数(类)var Person = function(name) {  // 这里的 this 绑定的就是 new 出来的那个实例对象<br/>  this.name = name;<br/>};// 定义 Person 函数(类)的原型对象Person.prototype = {<br/>  run: function() {    /**<br/>    * 这里的 this 并没有绑定在 Person.prototype 对象上<br/>    * 而是绑定在 new 出来的那个实例对象上<br/>    */<br/>    console.info(this.name + &#39;的 run 方法。&#39;);<br/>  }<br/>};var lily = new Person(&#39;lily&#39;);<br/>lily.run(); // lily的 run 方法。<br/></span>
🎜🎜obj.add🎜🎜メソッドを渡すことができます 🎜🎜this🎜 code>🎜それが属するオブジェクト🎜<code>🎜obj🎜🎜にアクセスします。これにより、オブジェクトから値を取得したり、オブジェクトを変更したりできます。このメソッドが呼び出されたときにオブジェクトへの this のバインドが発生します。 🎜🎜this🎜🎜 を通じて、所属するオブジェクトのコンテキストを取得できるメソッドは、パブリック メソッドと呼ばれます。 🎜🎜🎜🎜3. 関数呼び出しモード🎜🎜🎜🎜関数がオブジェクトのプロパティではない場合、関数として呼び出されます。 🎜🎜
🎜🎜例 1🎜🎜
<span style="font-size: 14px;">var add = function(a, b) {<br/>  return a + b;<br/>};var result = add.apply(null, [1, 2]);<br/>console.info(result); // 3<br/></span>
🎜🎜例 2🎜🎜
<span style="font-size: 14px;">var obj = {<br/>  name: &#39;obj&#39;,<br/>  introduction: function() {<br/>    console.info(&#39;My name is &#39; + this.name);<br/>  }<br/>};<br/>obj.introduction.apply(obj, []); // My name is objvar anotherObj = {<br/>  name: &#39;anotherObj&#39;};<br/><br/>obj.introduction.apply(anotherObj, []); // My name is anotherObj<br/></span>
🎜🎜 上の 2 つの例からわかるように、このモードで関数を呼び出すときは、これはグローバル オブジェクトにバインドされています。ここでメソッド呼び出しパターンに従って推論すると、これは外部関数にバインドされるはずですが、この設計上の欠陥は解決できないわけではありません。外部関数の this を変数に割り当てることができます。次の例: 🎜🎜
🎜🎜例 3🎜🎜
rrreee🎜🎜4. コンストラクター呼び出しモード🎜🎜🎜🎜を前に置くと、🎜🎜new🎜🎜 function を呼び出すと、関数の 🎜🎜prototype🎜🎜 メンバーに接続された新しいオブジェクトが内部的に作成され、これがその新しいオブジェクトにバインドされます。 🎜🎜

如果函数定义时内部存在<span style="font-size: 14px;">return</span>关键词,这时return 出去的就是<span style="font-size: 14px;">this</span>(新创建的对象)。

<span style="font-size: 14px;">// 定义一个 Person 函数(类)var Person = function(name) {  // 这里的 this 绑定的就是 new 出来的那个实例对象<br/>  this.name = name;<br/>};// 定义 Person 函数(类)的原型对象Person.prototype = {<br/>  run: function() {    /**<br/>    * 这里的 this 并没有绑定在 Person.prototype 对象上<br/>    * 而是绑定在 new 出来的那个实例对象上<br/>    */<br/>    console.info(this.name + &#39;的 run 方法。&#39;);<br/>  }<br/>};var lily = new Person(&#39;lily&#39;);<br/>lily.run(); // lily的 run 方法。<br/></span>

提示:一个函数,如果定义的目的就是结合 new 前缀来调用,那它就被称为构造函数。并且按照约定,它们定义的函数名以大写字母开头。

五、apply调用模式

因为JavaScript是一门函数式的面向对象编程语言,所以函数也可以拥有方法,apply就是<span style="font-size: 14px;">Function.prototype</span>上的一个方法。

apply方法让我们构建一个参数数组传递给调用函数,它还可以容许我们选择this的值。apply方法接受两个参数,第一个是要绑定 this 的值,第二个就是这个函数执行时的实参 参数 数组了。

例一

<span style="font-size: 14px;">var add = function(a, b) {<br/>  return a + b;<br/>};var result = add.apply(null, [1, 2]);<br/>console.info(result); // 3<br/></span>

例二

<span style="font-size: 14px;">var obj = {<br/>  name: &#39;obj&#39;,<br/>  introduction: function() {<br/>    console.info(&#39;My name is &#39; + this.name);<br/>  }<br/>};<br/>obj.introduction.apply(obj, []); // My name is objvar anotherObj = {<br/>  name: &#39;anotherObj&#39;};<br/><br/>obj.introduction.apply(anotherObj, []); // My name is anotherObj<br/></span>

总结:以上就是JavaScript中用到this的几种情况了,在面向对象中搞清楚this的指向是非常重要的,在JavaScript中也同等重要。

相关推荐:

javascript函数中的this的四种绑定形式

JS中的this、apply、call、bind实例分享

html的标签中的this应该如何使用

以上がJS におけるこの値の 4 つのモードの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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