js中typeof用法詳細介紹
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)返回”number” 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
// Numbers
typeof 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!
// Strings
typeof "" === 'string';
typeof "bla" === 'string';
typeof (typeof 1) === 'string'; // typeof always returns a string
typeof String("abc") === 'string'; // but never use this form!
// Booleans
typeof true === 'boolean';
typeof false === 'boolean';
typeof Boolean(true) === 'boolean'; // but never use this form!
// Symbols
typeof Symbol() === 'symbol'
typeof Symbol('foo') === 'symbol'
typeof Symbol.iterator === 'symbol'
// Undefined
typeof undefined === 'undefined';
typeof declaredButUndefinedVariable === 'undefined';
typeof undeclaredVariable === 'undefined';
// Objects
typeof {a:1} === 'object';
// use Array.isArray or Object.prototype.toString.call
// to differentiate regular objects from arrays
typeof [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';
// Functions
typeof function(){} === 'function';
typeof class C {} === 'function';
typeof Math.sin === 'function';
null
// This stands since the beginning of JavaScript
typeof 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 was
rejected. 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.1
typeof /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.
相關文章
- 超級詳細的tcpdump用法介紹TCP
- json詳細介紹(for Java)JSONJava
- MySQL5.6中的常用函式詳細用法介紹MySql函式
- Linux ls命令最詳細用法介紹Linux
- Spark SQL中對Json支援的詳細介紹SparkSQLJSON
- 一文搞懂js中的typeof用法JS
- js中getBoundingClientRect()的用法介紹JSGCclient
- javaScript系列:js中獲取時間new Date()詳細介紹JavaScriptJS
- javascript this詳細介紹JavaScript
- JDBC 詳細介紹JDBC
- Kafka詳細介紹Kafka
- Git詳細介紹Git
- CentOS中rpm命令詳細介紹CentOS
- Http協議中Cookie詳細介紹HTTP協議Cookie
- require.js用法介紹UIJS
- Android中Context的詳細介紹AndroidContext
- Go Channel 詳細介紹Go
- Nacos 介面詳細介紹
- MQ詳細命令介紹MQ
- Recovery命令詳細介紹
- Vmstat 命令詳細介紹
- js迴圈中reduce的用法簡單介紹JS
- js WebSocket用法簡單介紹JSWeb
- js的插入排序演算法詳細介紹JS排序演算法
- Flutter系列(一)——詳細介紹Flutter
- Nginx服務詳細介紹Nginx
- python字典詳細介紹Python
- Spring bean詳細介紹SpringBean
- Http Module 的詳細介紹HTTP
- Java異常詳細介紹Java
- 【SCN】Oracle SCN 詳細介紹Oracle
- SOLIDWORKS API詳細介紹SolidAPI
- Webpack 打包 Javascript 詳細介紹WebJavaScript
- mysql binlog詳細介紹MySql
- java泛型詳細介紹Java泛型
- 【工具】Sublime使用詳細介紹
- asmcmd工具的詳細介紹ASM
- Mysqldump工具的詳細介紹MySql