构造函数的原型对象中有一个constructor属性,指向构造函数本身

发布时间 2023-11-11 00:47:14作者: 龙陌

执行以下程序,下列选项中,说法正确的是()

function Person(age){

            this.age = age;

}

Person.sing = function(){console.log('我会唱歌');}

Person.prototype.getAge = function(){console.log(this.age);}

Person.age = 20;

var p = new Person(18);

console.log(Person.prototype.constructor);

A
输出结果为undefined

B
若要调用sing方法,可以使用p.sing();

C
若要调用getAge方法,可以使用p.getAge();

D
若要访问对象p的age属性,可以使用p.age,返回结果为20

正确答案:C

A选项,构造函数的原型对象中有一个constructor属性,指向构造函数本身,因此程序输出结果为构造函数,而不是undefined;

B选项,sing方法是定义在构造函数上的静态方法,调用时使用Person.sing(),而不能实例对象来调用;

C选项,getAge方法是定义在原型对象上,而原型对象上的方法可以使用实例对象来调用,原型对象方法中的this指向实例对象;

D选项,使用p.age可以访问实例对象p的age属性,结果为18。

A.选项,控制台打印结果为:ƒ Person(age){this.age = age;} 解释:构造函数的原型对象的构造器指回构造函数本身

B.选项 Person.sing = function(){console.log('我会唱歌');} 解释:这是给添加静态成员,给构造函数本身添加方法,想要访问静态成员,只能构造函数本身去调用方法,而由构造函数构造出来的实例对象不能访问直接访问静态成员(属性、方法)

C.选项 Person.prototype.getAge = function(){console.log(this.age);} 解释:给构造函数的原型对象上添加getAge方法让所有的实例化对象来共享这一个方法,实例化对象可以直接调用该添加的方法;

D.选项 返回结果为18