Home >Web Front-end >JS Tutorial >In-depth understanding of this, prototype and closure in js

In-depth understanding of this, prototype and closure in js

王林
王林forward
2019-08-21 15:34:542298browse

1. this keyword

a. There is an object pointing to the object;

b. There is no object pointing to the global variable (window);

c. There is new pointing to the new object produced by new;

d. Bind, call&apply changes the pointing of this;

e. SetTimeout/setInterval this points to window;

f. Arrow function this is determined when the function is defined;

var adder = {
  base : 1,
    
  add : function(a) {
    var f = v => v + this.base;
    return f(a);
  },

  addThruCall: function inFun(a) {
    var f = v => v + this.base;
    var b = {
      base : 2
    };
            
    return f.call(b, a);
  }
};
var obj = {
  i: 10,
  b: () => console.log(this.i, this),
  c: function() {
    console.log( this.i, this)
  }
}
obj.b();  // undefined window{...}原型
obj.c();  // 10 Object {...}

2. Prototype

prototype:

prototype:every An object will initialize an attribute inside it: prototype;

Prototype chain: When we access the properties of an object, if this property does not exist inside the object, then go back__proto__ Look for this attribute in , and keep looking for it: prototype chain;

instanceof The principle is to determine whether the __proto__ of the instance object and the prototype of the constructor that generated the instance refer to the same an address.

hasOwnProperty is the only function in JavaScript that handles properties without looking up the prototype chain.

In-depth understanding of this, prototype and closure in js

##Constructor ->prototype-> Prototype object-> constructor -> Constructor

Constructor-> new -> Instance object

Instance object-> __proto__-> Prototype object-> __proto__->Prototype object->->null

Execution context

The scope of variable declaration and function declaration will be raised to the top of the method body;

Scope:

a. JavaScript does not have block-level scope

b. In addition to the global scope, JavaScript only has scopes that functions can create. The scope is determined when the function is defined. rather than when the function is called.

Closure:

Concept: Internal functions can access variables in external functions;

Use: function as return value; function as parameter;

Function: encapsulate variables, converge permissions;

Disadvantages: consumes memory

Method to create objects:

Object literal;

Constructor;

Immediately execute function;

Object.create();

new object procedure:

Create new Object;

this points to this new object;

Execute code;

Return this;

Class and inheritance:

Class declaration:

function Animal(){
    this.name = 'name';
}
 
// es6 
 
class Animal2{
    constructor(){
        this.name = 'name2';
    }
}

Inheritance:

1. Implement inheritance with the help of constructor

function Parent(){
    this.name = 'parent';
}
 
function Child(){
    Parent.call(this);
    this.type = 'child1';
}

Disadvantages :

Partial inheritance;

Cannot inherit the methods on the prototype object of the parent class; (Only the attributes of the parent class are mounted to the child class, and Child's prototype has not changed to Child.prototype Cannot inherit Parent's prototype)

2. Prototype chain inheritance

function Parent(){
    this.name = 'name';
}
function Child(){
    this.type = 'child';
}
 
Child.prototype = new Parent();

缺点:原型链上原型对象是共用的。(原型的属性修改,所有继承自该原型的类的属性都会一起改变)

3.组合方式

function Parent(){
    this.name = 'parent';
}
function Child(){
    Parent.call(this);
    this.type = 'child';
}
Child.prototype = new Parent();

缺点:

父类执行函数执行两次;

constructor指向父类;

function Parent(){
    this.name = 'parent';
}
function Child(){
    Parent.call(this);
    this.type = 'child';
}
Child.prototype = Parent.prototype;

缺点:

子类constructor指向父类

function Parent(){
    this.name = 'parent';
}
function Child(){
    Parent.call(this);
    this.type = 'child';
}
Child.prototype = Object.create(Parent.prototype);
Child.prototype.constructor = Child;

优点:

子类的原型指向Object.create(Parent.prototype),实现了子类和父类构造函数的分离,但是这时子类中还是没有自己的构造函数,

所以紧接着又设置了子类的构造函数,由此实现了完美的组合继承。(也就是把父类的prototype写入子类的prototype,在定义子类的constructor)

4. es6

class Child extends Parent {
    constructor(){
 
    }
}

希望本文中的内容能够帮到学习JavaScript的同学。谢谢!

更多JavaScript的相关问题请访问PHP中文网:https://www.php.cn/

The above is the detailed content of In-depth understanding of this, prototype and closure in js. For more information, please follow other related articles on the PHP Chinese website!

Statement:
This article is reproduced at:csdn.net. If there is any infringement, please contact admin@php.cn delete