执行以下程序,下列选项中,说法错误的是()
class Phone{
constructor(brand){
this.brand = brand;
}
call(){}...①
}
function playGame(){console.log("我可以打游戏")};
function photo(){console.log("我可以拍照")};
console.log(typeof Phone);...②
var p = new Phone('华为');
console.log(p.brand);...③
类的所有实例方法均定义在类的原型对象上,因此,在类内定义的实例方法和在类的原型对象上定义方法是等价的,
call()是实例方法,故A选项说法正确,不符合题意;
类的本质是函数,实际上,ES6中的类可以视为ES5中构造函数的另一种写法,所以②式的输出结果为function而不是Object,B选项说法错误,符合题意;
p为类的实例对象,该对象有一个属性brand,属性值为华为,C选项说法正确,不符合题意;
Object.assign(target, source)可将source源对象所有可枚举的属性(或方法)分配给target对象,所以可以使用Object.assign(Phone.prototype,{playGame,photo})为类一次性添加playGame和photo两个实例方法,D选项说法正确,不符合题意。
typeof返回的类型
number、string、boolean、undefined、function、object共6种。
注意:其中Array与null返回的都是object
function(){}与class{}返回的都是function
class不过是构造函数语法糖而已
标签:function,console,定义,brand,实例,原型,log,题意 From: https://www.cnblogs.com/longmo666/p/17824628.html