第九章 类和模块
1、在JS中,类的实现是基于其原型继承机制的,如果两个实例都从同一个原型对象上继承了属性,我们说它们是同一个实例。
2、常见的编程约定:定义构造函数既是定义类,并且类名首字母要大写。
3、构造函数会初始化this,不必返回新创建的对象,构造函数会自动创建对象,然后将构造函数作为这个对象的方法来调用一次,最后返回这个新对象。
4、构造函数就是构造新对象的,它必须通过关键字new调用,如果构造函数用作普通函数,往往不会正常工作。
5、对Range()构造函数的调用会自动使用Range.prototype作为新Range对象的原型。
6、每个JS函数都自动拥有一个prototype属性。这个属性值是一个对象,包含唯一一个不可枚举属性constructor。constructor的值是一个函数对象。
7、在JS中定义类的步骤可以缩减为一个分三步的算法:第一步,先定义一个构造函数,并设置初始化新对象的实例属性。第二步,给构造函数的prototype对象定义实例的方法。第三步,给早函数定义类字段和类属型。
8、类的实例方法定义为原型对象的函数值属性。JS的实例方法必须使用关键字this来存取实例的字段。
9、类字段,比如常量和类方法直接定义为构造函数的属性,类的方法通常不使用关键字this,它们只对其参数进行操作。
10、JS中基于原型的继承机制是动态的:对象从其原型继承属性,如果创建对象之后原型的属性发生改变,也会影响到继承这个原型的所有实例对象。
11、instanceof运算符和isPrototypeOf()方法的缺点是,我们无法通过对象来获得类名,只能检测对象是否属于指定的类名。在客户端JS中,在多窗口和多框架子页面中的Web应用中兼容性不佳。每个窗口和框架子页面都具有单独的执行上下文,每个上下文都包含独有的全局变量和一组构造函数。在两个不同框架页面中创建的两个数组继承自两个相同但相互独立的原型对象,其中一个框架页面中的数组不是另一个框架页面的Array()构造函数ude实例,instanceof的结果是false。
12、使用constructor属性检测对象属于某个类的技术的不足之处和instanceof一样,在多个执行上下文的场景中它是无法正常工作的。而且在JS中并非所有的对象都包含constructor属性。
13、我们可以通过将变量或参数闭包在一个构造函数内来模拟实现私有实例字段,调用构造函数会创建一个实例。为了做到这一点,需要在构造函数内部定义一个函数,因此这个函数可以访问构造函数内部的参数和变量,并将这个函数赋值给新创建对象的属性。这种封装技术造成了更多系统开销。使用闭包来封装类的状态的类一定会比不使用封装的状态变量的等价类运行速度更慢,并占用更多内存。