null和undefined在js中都是标识“无” 在其表现意义上并没有太大的差别
null==undefined //true
但是又在null===undefined //false
其实在这里就基本已经明了了 null和undefined的类型不同
期初的js设计是只有 null表示空 可以自动转换成0标识false
null 所表示的形式是说明没有这个对象 转数字为0
undefined 则表示没有这个值 转数字为NaN
Number(undefined)// NaN
Number(null) // 0
NAN :为特殊的一种number类型 可以用isNAN来判断值是否为NaN
例:isNaN(Number('a')) //true isNaN(Number(1))//false
NaN有一个重要的特性与所有值都不等 甚至 NaN===NaN //false 这不禁让人想到了es6的Symbol(* Symbol 是原始数据类型 不是对象 )
let sy = Symbol("KK");
console.log(sy); // Symbol(KK)
typeof(sy); // "symbol"
// 相同参数 Symbol() 返回的值不相等
let sy1 = Symbol("kk");
sy === sy1; // false
以为Symbol的独立性性可用做对象的key
let sy = Symbol("key1");
// 写法1
let syObject = {};
syObject[sy] = "kk";
console.log(syObject); // {Symbol(key1): "kk"}
// 写法2
let syObject = {
[sy]: "kk"
};
console.log(syObject); // {Symbol(key1): "kk"}
// 写法3
let syObject = {};
Object.defineProperty(syObject, sy, {value: "kk"});
console.log(syObject); // {Symbol(key1): "kk"}
Symbol 值作为属性名时,该属性是公有属性不是私有属性,可以在类的外部访问。但是不会出现在 for...in 、 for...of 的循环中,也不会被 Object.keys() 、 Object.getOwnPropertyNames() 返回。如果要读取到一个对象的 Symbol 属性,可以通过 Object.getOwnPropertySymbols() 和 Reflect.ownKeys() 取到。
还未完成随时更新。。。