js中typeof用法详细介绍
来源:互联网 发布:app软件价格 编辑:程序博客网 时间:2024/06/03 13:05
typeof 运算符把类型信息当作字符串返回。typeof 返回值有六种可能: "number," "string," "boolean," "object," "function," 和 "undefined."我们可以使用typeof来获取一个变量是否存在,如if(typeof a!="undefined"){},而不要去使用if(a)因为如果a不存在(未声明)则会出错,对于Array,Null等特殊对象使用typeof一律返回object,这正是typeof的局限性。
typeof 语法中的圆括号是可选项。
if(document.mylist.length != “undefined” ) {} 这个用法有误.
正确的是 if( typeof(document.mylist.length) != “undefined” ) {}
或 if( !isNaN(document.mylist.length) ) {}
typeof的运算数未定义,返回的就是 “undefined”.
运算数为数字 typeof(x) = “number”
字符串 typeof(x) = “string”
布尔值 typeof(x) = “boolean”
对象,数组和null typeof(x) = “object”
函数 typeof(x) = “function”
typeof 运算符返回一个用来表示表达式的数据类型的字符串。
可能的字符串有:”number”、”string”、”boolean”、”object”、”function” 和 “undefined”。
如:
alert(typeof (“123″));//typeof(“123″)返回”string”
对于Array,Null等特殊对象使用typeof一律返回object,这正是typeof的局限性。
如果我们希望获取一个对象是否是数组,或判断某个变量是否是某个对象的实例则要选择使用instanceof。instanceof用于判断一个变量是否某个对象的实例,如var a=new Array();alert(a instanceof Array);会返回true,同时alert(a instanceof Object)也会返回true;这是因为Array是object的子类。再如:function test(){};var a=new test();alert(a instanceof test)会返回true。
友情提示
a instanceof Object 得到true并不是因为 Array是Object的子对象,而是因为 Array的prototype属性构造于Object,Array的父级是Function
Examples
// Numberstypeof 37 === 'number';typeof 3.14 === 'number';typeof(42) === 'number';typeof Math.LN2 === 'number';typeof Infinity === 'number';typeof NaN === 'number'; // Despite being "Not-A-Number"typeof Number(1) === 'number'; // but never use this form!// Stringstypeof "" === 'string';typeof "bla" === 'string';typeof (typeof 1) === 'string'; // typeof always returns a stringtypeof String("abc") === 'string'; // but never use this form!// Booleanstypeof true === 'boolean';typeof false === 'boolean';typeof Boolean(true) === 'boolean'; // but never use this form!// Symbolstypeof Symbol() === 'symbol'typeof Symbol('foo') === 'symbol'typeof Symbol.iterator === 'symbol'// Undefinedtypeof undefined === 'undefined';typeof declaredButUndefinedVariable === 'undefined';typeof undeclaredVariable === 'undefined'; // Objectstypeof {a:1} === 'object';// use Array.isArray or Object.prototype.toString.call// to differentiate regular objects from arraystypeof [1, 2, 4] === 'object';typeof new Date() === 'object';// The following is confusing. Don't use!typeof new Boolean(true) === 'object'; typeof new Number(1) === 'object'; typeof new String("abc") === 'object';// Functionstypeof function(){} === 'function';typeof class C {} === 'function';typeof Math.sin === 'function';
null
// This stands since the beginning of JavaScripttypeof null === 'object';
In the first implementation of JavaScript, JavaScript values were represented as a type tag and a value. The type tag for objects was 0. null
was represented as the NULL pointer (0x00 in most platforms). Consequently, null had 0 as type tag, hence the bogus typeof
return value. (reference)
A fix was proposed for ECMAScript (via an opt-in), but wasrejected. It would have resulted intypeof null === 'null'
.
Regular expressions
Callable regular expressions were a non-standard addition in some browsers.
typeof /s/ === 'function'; // Chrome 1-12 Non-conform to ECMAScript 5.1typeof /s/ === 'object'; // Firefox 5+ Conform to ECMAScript 5.1
Exceptions
All current browsers expose a non-standard host object document.all
with type Undefined.
typeof document.all === 'undefined';
Although the specification allows custom type tags for non-standard exotic objects, it requires those type tags to be different from the predefined ones. The case of document.all
having type tag'undefined'
must be classified as an exceptional violation of the rules.
- js中typeof用法详细介绍
- js中typeof用法详细介绍
- js中typeof用法详细介绍及NaN、 null 及 undefined 的区别
- json,js中typeof用法详细介绍及NaN、 null 及 undefined 的区别
- js中typeOf用法
- js中typeOf用法
- js中typeOf用法
- js中typeOf用法
- JS中typeof用法
- js 中 typeOf 用法
- js中typeOf用法
- JS中typeof用法
- JS中typeof()的用法
- js中typeof的用法
- js中typeof的用法
- js中typeof的用法
- js中typeof的用法
- js中typeof的用法
- POJ 3468-A Simple Problem with Integers
- 11、新手入手树莓派教程--Qt中使用wiringPi来驱动RGB灯、使用opencv打开摄像头
- Lintcode:插入区间
- SolidWorks二次开发——套合件(零件嵌入零件)
- 软件行业里学历和资历哪个更重要?
- js中typeof用法详细介绍
- 快速打造自己开发环境 vagrant + virtualbox
- ReactJs中的网络请求fetch 使用及封装
- ViewPager+Fragment嵌套ViewPager+Fragment
- Handler机制
- JAVA Socket编程学习8--为什么使用Netty
- HDOJ 1031 Design T-Shirt
- 亚马逊高级应用科学家熊元骏:人类行为理解研究进展 | PhD Talk #19
- 直播预告 | 亚马逊高级应用科学家熊元骏:人类行为理解研究进展