展会信息港展会大全

JavaScript中的typeof操作符用法实例
来源:互联网   发布日期:2016-01-26 10:59:30   浏览:1056次  

导读:在Web前端开发中,我们经常需要判断变量的数据类型。鉴于ECMAScript是松散类型的,因此需要有一种手段来检测给定变量的数据类型 typeof就是负责提供这方便信息的操作符。对一个值使用typeof操作符可能返回下 ...

在Web前端开发中,我们经常需要判断变量的数据类型。鉴于ECMAScript是松散类型的,因此需要有一种手段来检测给定变量的数据类型typeof就是负责提供这方便信息的操作符。

对一个值使用typeof操作符可能返回下列某个字符串:

undefined如果这个值未定义

boolean如果这个值是布尔值

string如果这个值是字符串

number如果这个值是数值

object如果这个是对象或null

function如果这个值是函数

常用的typeof操作符的返回值包括number、string、boolean、undefined 、object和function。如:

代码如下:

var n;

console.log(typeof n); // "undefined"

n = 1;

console.log(typeof n); // "number"

n = "1";

console.log(typeof n); // "string"

n = false;

console.log(typeof n); // "boolean"

n = { name: "obj" };

console.log(typeof n); // "object"

n = new Number(5);

console.log(typeof n); // "object"

n = function() { return; };

console.log(typeof n); // "function"

这几个例子说明,typeof操作符的操作数可以是变量(message),也可以是数值字面量。注意,typeof是一个操作符而不是函数,因此例子中的圆括号不是必须的(尽管可以使用)。

从上面的例子中,我们发现用Number()创建的数字也会被typeof判定为对象而返回值 object ,这是因为构造函数返回的都是对象,那么如果我们想要区分数字对象(Number)、字符串对象(String)、数组对象(Array)、Function对象、日起对象(Date)、布尔对象(Boolean)以及错误对象(Error)等JavaScript内置对象时,怎么办呢?在这里可以调用对象的 toString方法,如:

代码如下:

var n, res;

n = new Number(66);

res = Object.prototype.toString.call(n);

console.log(res); // "[object Number]"

n = new String("string");

res = Object.prototype.toString.call(n);

console.log(res); // "[object String]"

n = [];

res = Object.prototype.toString.call(n);

console.log(res); // "[object Array]"

// ...

赞助本站

人工智能实验室

相关热词: typeof JavaScript

AiLab云推荐
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港