面向对象编程(Object Oriented Programming,缩写为 OOP)是目前主流的编程范式。它将真实世界各种复杂的关系,抽象为一个个对象,然后由对象之间的分工与合作,完成对真实世界的模拟。
javaScript使用构造函数(constructor)作为对象的模板。所谓”构造函数”,就是专门用来生成实例对象的函数。它就是对象的模板,描述实例对象的基本结构。
构造函数就是一个有自己特征和用法的“普通函数”。例如:
var Person = function(name.sex){
this.name = name; // 姓名
this.age =age; // 年龄
}
上面代码,Person
就是一个构造函数,人都有姓名和年龄。为了把构造函数和普通函数进行区别,构造函数名字的首字母通常大写。
构造函数有两个特点:
this
关键字,代表要生成的实例。new
命令。new
命令的作用就是执行构造函数,返回一个实例对象。
var Car = function(){
this.price = 1000;
}
var c = new Car();
c.price; // 1000
构造函数根据需要,可以接受参数。
var Animal = function(type,sex){
this.type = type; // 动物种类
this.sex = sex; // 动物性别
}
var a = new Animal("哺乳动物",1);
a.type; // “哺乳动物”
a.sex; // 1,用1表示公,0表示母
new
命令本身就可以执行构造函数,所以后面的构造函数可以带括号,也可以不带括号。
// 推荐写法
var c = new Car();
//不推荐写法
var c = new Car;
如果不使用new
命令,直接调用构造函数,构造函数就变成了普通函数,并不会生成实例对象。
var Car = function(){
this.price = 1000;
}
// 不使用new命令,此此时this指向全局对象
var c = Car();
c; // underfined
c.price; // Uncaught TypeError: Cannot read property 'price' of undefined
price; // 1000
为了保证构造函数必须与new
命令一起使用,可以通过以下手段实现:
new
命令,如果发现没有使用,则直接返回一个实例对象。//使用严格模式
function Vehicle(speed,color){
"use strict" // 第一行加上 “use strict”,开启严格模式
this.speed = speed;
this.color = color;
}
var v = Vehicle(100, "red"); // TypeError: Cannot set property 'speed' of undefined at Vehicle
// 构造函数内部判断是否使用了new命令,没有直接返回一个实例对象
function Vehicle(speed,color){
if(!(this instanceof Vehicle)){
return new Vehicle(speed,color);
}
this.speed = speed;
this.color = color;
}
使用new
命令时,它后面的函数依次执行下面的步骤:
prototype
属性。this
关键字。构造函数内部,this
指的是一个新生成的空对象,所有针对this
的操作,都会发生在这个空对象上。
如果构造函数内部有return
语句,而且return
后面跟着一个对象,new
命令会返回return
语句指定的对象;否则,就会不管return
语句,返回this
对象。
// 构造函数内部返回一个对象
var Vehicle = function (){
this.price = 1000;
return { price: 2000 };
};
(new Vehicle()).price; // 2000
// 构造函数内部返回一个数值
var Vehicle = function () {
this.price = 1000;
return 2000;
};
new Vehicle().price; // 1000
对普通函数(内部没有this
关键字)使用new
命令,如果函数内部有return
语句,且跟着一个对象,则返回return
语句指定的对象;否则,返回空对象。
// 普通函数返回一个对象
function getMessage() {
return {'p':'this is a message'};
}
var msg = new getMessage();
msg // {p: "this is a message"}
// 普通函数返回一个字符串
function getMessage() {
return 'this is a message';
}
var msg = new getMessage();
msg // {}
函数内部可以使用new.target
属性。如果当前函数是new
命令调用,new.target
指向当前函数,否则为undefined
。
function f() {
console.log(new.target === f);
}
f() // false
new f() // true
本篇博文是我自己学习笔记,原文请参考阮一峰javaScript教程。
如有问题,请及时指出!
欢迎沟通交流,邮箱:[email protected]。