什么是构造函数?

this指向的几种状况数组

1.全局中调用app

    this.name //this指向window对象
   
2.函数调用函数

    test();//test()函数中的this也指向window对象
   
3.对象的方法调用this

    obj1.fn();//obj1对象的fn()方法中的this指向obj1
   
4.调用构造函数
    var dog=new Dog();//构造函数内的this指向新建立的实例对象,也就是这里的dogcall和applyspa

call和apply的做用同样,只是接受参数的方式不同,call接受的是多个单个参数,apply接受的是参数数组。
call和apply的做用简单地能够说成,当一个对象实例缺乏一个函数/方法时,能够调用其余对象的现成函数/方法,其方式是经过替换其中的this为这个对象实例,改变函数运行时的上下文。.net

普通函数与构造函数相比有四个明显特色:prototype

1.不须要用new关键字调用code

    fn();2.能够用return语句返回值htm

 
1
2
3
4
function fn(a,b){
    return a+b;
  }
  alert(fn(2,3)); //alert:5

3.函数内部不建议使用this关键字
咱们说不建议使用,固然硬要用是能够的,只是要注意这时候发生了什么。若是在普通函数内部使用this关键字定义变量或函数,由于这时候this指向的是window全局对象,这样无心间就会为window添加了一些全局变量或函数。对象

 
1
2
3
4
5
6
function greeting(){
     this .name= "sheila" ;
     alert( "hello " + this .name);
   }
   greeting(); //alert:hello sheila
   alert(window.name); //alert:sheila

4.函数命名以驼峰方式,首字母小写

构造函数
在JavaScript中,用new关键字来调用定义的构造函数。默认返回的是一个新对象,这个新对象具备构造函数定义的变量和函数/方法。

举个例子:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
function Prince(name,age){
   this .gender= "male" ;
   this .kind= true ;
   this .rich= true ;
   this .name=name;
   this .age=age;
}
Prince.prototype.toFrog= function (){
   console.log( "Prince " + this .name+ " turned into a frog." );
}
var prince= new Prince( "charming" ,25);
prince.toFrog(); //Prince charming turned into a frog.
prince.kind; //true

与普通函数相比,构造函数有如下明显特色:

1.用new关键字调用

new关键字来完成:
a、建立一个空对象;
b、将关键字this指向这个空对象;
c、执行构造函数里面的代码,给当前空对象this设置属性和方法;
d、将this这个当前对象返回。

    var prince=new Prince("charming",25);

2.函数内部可使用this关键字
在构造函数内部,this指向的是构造出的新对象。用this定义的变量或函数/方法,就是实例变量或实例函数/方法。须要用实例才能访问到,不能用类型名访问。

 prince.age;//25
    Prince.age;//undefined

3.默认不用return返回值
构造函数是不须要用return显式返回值的,默认会返回this,也就是新的实例对象。固然,也能够用return语句,返回值会根据return值的类型而有所不一样,细节将在下文介绍。

4.函数命名建议首字母大写,与普通函数区分开。
不是命名规范中的,可是建议这么写。

1.第一步,建立一个空对象。

var prince={}

2.第二步,将构造函数Prince()中的this指向新建立的对象prince。 3.第三步,将prince的_proto_属性指向Prince函数的prototype,建立对象和原型间关系 4.第四步,执行构造函数Prince()内的代码。

相关文章
相关标签/搜索