数据类型js的数据类型

62次阅读

共计 2064 个字符,预计需要花费 6 分钟才能阅读完成。

一、js 的数据类型有基本数据类型和引用类型

基本数据类型包括:undefined, null,boolean,number,string
引用类型是 object:包括 function,array,Date…

【es6 新增类型】
1. set 集合,区别于数组的就是 set 中不可以有重复的数据,常可以用来做去重操作

  • 含有 size 属性,集合里元素的个数
  • add 方法,返回的是原对象改变后的值
  • delete 方法,返回值是 true/false
  • has(‘data1’) 返回值是 true/false
  • myset.keys(); myset.value()

2. Map 类型,与对象的区别是:对象的键值只能是字符串,不可以是对象类型,使用 Map 类型可以避免键值必须是字符串的限制,可以是对象,数组等

  • 创建的时候一个大的数组,每一项元素是小数组,小数组有两个元素,分别是一组对应的 key,value。
  • 方法:
  • set(key,value); get(key);
  • delete(key); has(key); // 返回值均是 true/false
  • mymap.forEach(function (value,key) {
    console.log(key+”:”+value);
    }) // 遍历,参数是 value,key【注意顺序】
  • mymap.set({},”obj1″);
  • mymap.set({},”obj2″); 这是两个不同的键值,不会被覆盖

3.Symbol 类型 用相同的字符串做属性名命名的时候会发生命名冲突,使用 Symbol 产生的名字是不同的

  • Symbol 即便传入相同的参数,两者的值也是不一样的 例:Symbol(‘foo’) !== Symbol(‘foo’);
  • 如果想让两者相等,可以使用 Symbol.for() 例 Symbol.for(‘bar’) === Symbol.for(‘bar’)
  • 但是 Symbol(‘bar’) !== Symbol.for(‘bar’);
    如果 Symbol 作为属性名,不会被 Object.keys() Object.getOwnPropertyNames()、JSON.stringify()返回; 该属性也不会出现在 for…in、for…of 循环中。但是,它也不是私有属性,有一个 Object.getOwnPropertySymbols 方法,可以获取指定对象的所有 Symbol 属性名。

typeof null 返回值是“object”,null 会被认为是一个空对象的引用
null == undefined //true
当定义一个变量用来保存对象,就可以将这个变量初始化为 null

实现继承
function Person(){}
function Student(){}
Student.prototype = new Person()
Student.prototype.constructor= Student
var bosn= new Student()
bosn instanceof Student //true
bosn instanceof Person // true

二、判断类型的方式

typeof | instanceof | Object.prototype.toString.apply()

  1. typeof: 适用于基本类型和 function,object 具体是数组还是对象识别不了,null 也是别不了

    typeof [1,2]   // 'object'
    typeof '123'   //'string'
    typeof null     // 'object'
    typeof undefined  //'undefined'
    typeof function(){}   //'function'
    typeof new Object()  //'object'
  2. instanceof: 适合自定义对象和原生对象,检查 prototype

     [1,2] instanceof Array  //true
  3. Object.prototype.toString.apply() 适合基本对象和内置对象,IE6、7、9 中 null 和 undefined 失效

三、空数组的问题

   [] == false   //true        任意值与布尔值比较,都会将两边的值转化为 Number;Number([]) 为 0    Number(false)也是 0    所以[] == false 为 true
   [] ==![]     // true          Number([]) = 0;  Number(![]) = 0 ;   所以 []==![] 为 true
   new Array(1) == false;  //true    new Array(1)==> [empty]  ,  Number(new Array(1)) = 0   
   Boolean([])   //true
   if([]){console.log(1)}  // 此时[] 是 true
   NaN == NaN  // false   
   null == undefined  //true

四、Number 强制转换数字

  1. 如果参数是 Date 对象,Number()会返回从 1970 年 1 月 1 日至今的毫秒数
  2. 如果字符串截去开头和结尾的空白字符后,不是纯数字字符串,那么最终返回结果为 NaN。
  3. 数组转数字,如果数组长度大于 1,返回 NaN;数组只有一项,对第一项转数字;

正文完
 0