JavaScript 基础知识系列:数据类型及slice(8,-1)

在基础类库中常见的slice(8,-1)是个什么鬼?下面就从js数据类型说起。

javascrip数据类型有两种:

  1. 基本类型:Undefined,Null,Boolean,Number,String
  2. 引用类型:
    • 第一类:原生对象:object,Array,Date,RegExp,Function以及有基本类型衍生出来的包装类型Boolean,Number,String;
    • 第二类内置对象(JS语言提供的不依赖于执行宿主的对象,如Global,Math)
    • 宿主对象(JS语言提供的任何依赖宿主环境的对象,如IE中的window,WS中的WScript实例,以及任何用户创建的类)

数据类型的判断方式:

1、typeof判断数据类型会返回一个字符串,如

 

 1 // Numbers
 2 typeof 37 === 'number';
 3 typeof 3.14 === 'number';
 4 typeof Math.LN2 === 'number';
 5 typeof Infinity === 'number';
 6 typeof NaN === 'number'; // 尽管NaN是"Not-A-Number"的缩写,意思是"不是一个数字"
 7 typeof Number(1) === 'number'; // 不要这样使用!
 8 
 9 // Strings
10 typeof "" === 'string';
11 typeof "bla" === 'string';
12 typeof (typeof 1) === 'string'; // typeof返回的肯定是一个字符串
13 typeof String("abc") === 'string'; // 不要这样使用!
14 
15 // Booleans
16 typeof true === 'boolean';
17 typeof false === 'boolean';
18 typeof Boolean(true) === 'boolean'; // 不要这样使用!
19 
20 // Symbols
21 typeof Symbol() === 'symbol';
22 typeof Symbol('foo') === 'symbol';
23 typeof Symbol.iterator === 'symbol';
24 
25 // Undefined
26 typeof undefined === 'undefined';
27 typeof blabla === 'undefined'; // 一个未定义的变量,或者一个定义了却未赋初值的变量
28 
29 // Objects
30 typeof {a:1} === 'object';
31 
32 // 使用Array.isArray或者Object.prototype.toString.call方法可以从基本的对象中区分出数组类型
33 typeof [1, 2, 4] === 'object';
34 
35 typeof new Date() === 'object';
36 
37 // 下面的容易令人迷惑,不要这样使用!
38 typeof new Boolean(true) === 'object';
39 typeof new Number(1) ==== 'object';
40 typeof new String("abc") === 'object';
41 
42 // 函数
43 typeof function(){} === 'function';
44 typeof Math.sin === 'function';

 

typeof在针对 对象、日期、正则、数组上的判断并不准确,返回的都是“object”,因此,我们需要另外一种办法来准确判断数据类型。

2、Object.prototype.toString()

该方法返回描述某个对象数据类型的字符串,如自定义的对象没有被覆盖,则会返回“[object type]”,其中,type则是实际的对象类型。在使用该方法检测的时候,可以使用Object.prototype.toString.call()或者Object.prototype.toString.apply()进行测试,如

1 var toString = Object.prototype.toString;
2 toString.call(new Date);//[object Date]
3 toString.call(new String);//[object String]
4 toString.call(Math);//[object Math]
5 toString.call(undefined);//[object Undefined]
6 toString.call(null);//[object Null]

因此,引出Object.prototype.toString.call(obj).slice(8,-1),如

Object.prototype.toString.call('ESStudio balabala……');
//"[object String]"
Object.prototype.toString.call('ESStudio balabala……').slice(8,-1);
//"String"

slice(startIndex,endIndex),从0开始索引,其中8代表从第8位(包含)开始截取(本例中代表空格后面的位置),-1代表截取到倒数第一位(不含),所以正好截取到[object String]中的String。

结题。

 

转载于:https://www.cnblogs.com/EFPlatform/p/10141360.html

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值