下面对知识点总结:css
a.原始类型:number, string, boolean, null, undefined编程
b.对象类型:除了原始类型都是(例如:object,array, function, new xxx[构造函数 class对象 Date, RegExp, Error])编程语言
备注:NAN,非数字,与任何值都不等,包括NAN函数
任何二进制浮点数的编程语言中,都会出现如下问题.所以咱们在金融的计算业务中,使用整数计算(例如使用1分代替0.01元)this
var a = 0.3 - 0.2; var b = 0.2 - 0.1; console.log( a == b); // false
for ....in : 遍历本身可枚举的属性+ 继承的可枚举属性 Object.isOwnProperty(Object, property): 判断是不是本身的属性
对象上有两种属性:通常的属性和存取器属性。prototype
var object = { x: 10, // 通常属性 get y() { return 3*this.x}, set y(num) { this.x = num + this.x;} }; object.y // 30 object.y = 20; // x = 30;
object.y // 120
例如例子,复制属性的特性对象
Object.defineProperty(Object.prototype, 'extend', { writable: true, enumerable: false, configurable: true, value: function(o) { var names = Object.getOwnPropertyNames(o); for( var i = 0; i < names.length; i ++) { console.log(name[i]); if(names[i] in this) { continue; } else { Object.defineProperty(this, names[i], Object.getOwnPropertyDescriptor(o, names[i])) } } } } ) var a = {x:1}; var b ={y: 2}; a.extend(b); //{x:1,y: 2}
1.字面量建立 var object = {a: 1}; // prototype: Object.prototype
Object.prototype.isPrototypeOf(object); // true 2. new 方式建立 function a() {} var object = new a(); // prototype: a.prototype
object.__prop__ == a.prototype; // true a.prototype
a.prototype.isPrototypeOf(object); // true 3.Object.create() var object = Object.create({y: 1}); // prototype: Object.prototype:
Object.prototype.isPrototypeOf(obejct); // true
// Object.prototype: 就是Object的构造函数
// a.prototype: 就是a的构造函数
a.prototypeblog
b.class 类属性继承
通常是取对象的toString()方法的第8个到倒数第二个位置的字符串 function A() {} console.log(A.toString().substring(8, -1)); // Function 若是toString方法被重写,就不能够经过这种方式完成,能够经过如下方式: function classOf(o) { if(o === null ) { return 'null'}; if(o === undefined) { return 'undefined'} return Object.prototype.toString.call(o).slice(8,-1) } function A() {} classOf(A) // Function
c.可拓展性ip
表示对象是否能够添加新的属性。
Object.isExtensible(): 判断是否可拓展 Object.preventExtensions(obj); // 设置不可拓展 // 与上同理,可是能够将属性设置为不可配 Object.isSealed() Object.seal(obj) //冻结, 更严格锁定对象,不只能够设置不可拓展和将属性设置为不可配,能够将全部数据设置为只读(存取器属性不受影响) Object.freeze() Object.isFrozen()