網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
判斷數(shù)據(jù)類型的方法
1.typeof
- 語(yǔ)法:
typeof operand || typeof(operand)
operand可以是變量或者表達(dá)式
類型 | 返回值 |
---|---|
Number | number |
String | string |
Boolean | boolean |
Undefined | undefined |
Null | object |
Symbol | symbol |
Obejct | object |
Array | object |
Function | object |
其他對(duì)象 | object |
2.instanceof
- 語(yǔ)法:
object instanceof constructor
object為實(shí)例對(duì)象 constructor為構(gòu)造函數(shù)
-
js內(nèi)置構(gòu)造函數(shù):
- Array
- Date
- Error
- Function
- Object
- RegExp
-
用途:
- 用來(lái)檢查object是否為constructor的實(shí)例對(duì)象
- 可用來(lái)判斷對(duì)象類型
- 不可判斷原始類型
- 示例:
var arr=[1,2,3]
console.log(arr instanceof Array) //true
var arr=[1,2,3]
console.log(arr instanceof Object) //true
var reg=/^\d{3,}$/
console.log(reg instanceof RegExp) //true
function Person(){};
var student = new Person();
console.log(peason1 instanceof Person) //true
3.Array.isArray()
- 語(yǔ)法:
Array.isArray()
-
用途:
- 用于檢測(cè)某變量是否為數(shù)組,返回值是Boolean型
- 示例:
var arr = [1,2,3]
Array.isArray(arr) //true
4.Object.prototype.toString.call()
- 語(yǔ)法:
Object.prototype.toString.call()
括號(hào)內(nèi)輸入需要判斷的內(nèi)容
同時(shí)可以使用slice方法截取返回值
Object.prototype.toString.call().slice(8,-1)
-
用途:
- 用于判斷瀏覽器內(nèi)置對(duì)象
- 可判斷所有數(shù)據(jù)類型
- 返回值是字符串
-
示例:
Object.prototype.toString.call(1).slice(8,-1) //'Number'
Object.prototype.toString.call('').slice(8,-1) //'String'
Object.prototype.toString.call(true).slice(8,-1) //'Boolean'
Object.prototype.toString.call(undefined).slice(8,-1) //'Undefined'
Object.prototype.toString.call(null).slice(8,-1) //'Null'
Object.prototype.toString.call([]).slice(8,-1) //'Array'
Object.prototype.toString.call({}).slice(8,-1) //'Object'
Object.prototype.toString.call(function(){}).slice(8,-1) //'Function'
Object.prototype.toString.call(new Date).slice(8,-1) //'Date'
5.constructor
- 語(yǔ)法:
object.constructor
-
用途:
- constructor屬性返回對(duì)象的構(gòu)造函數(shù)
- 且返回值是函數(shù)的引用
- 不是函數(shù)名
- 示例:
[].constructor === Array //true
Number(1).constructor === Number //true
''.constructor === String //true
new Date().constructor === Date //true
new Error().constructor === Error //true
true.constructor === Boolean //true
-
注意:
- null和undefined沒有constructor,這兩種類型的數(shù)據(jù)需要通過(guò)其他方式判斷
- 同時(shí)函數(shù)的constructor是不穩(wěn)定的,這個(gè)主要體現(xiàn)在自定義對(duì)象上,當(dāng)開發(fā)者重寫protype后,原有的constructor引用會(huì)丟失,constructor會(huì)默認(rèn)為Object
原文鏈接:https://blog.csdn.net/SH744/article/details/126824792
相關(guān)推薦
- 2022-02-23 C#使用log4net記錄日志_C#教程
- 2022-11-18 Oracle移動(dòng)數(shù)據(jù)文件不停機(jī)和停機(jī)兩種方式詳解_oracle
- 2022-06-30 卷積神經(jīng)網(wǎng)絡(luò)經(jīng)典模型及其改進(jìn)點(diǎn)學(xué)習(xí)匯總_python
- 2022-12-10 C++?Boost?Spirit精通教程_C 語(yǔ)言
- 2022-04-24 C語(yǔ)言浮點(diǎn)函數(shù)中的modf和fmod詳解_C 語(yǔ)言
- 2022-07-22 防火墻.iptables-tcp-flags防止nmap端口掃描
- 2022-10-16 Ant?Design?組件庫(kù)按鈕實(shí)現(xiàn)示例詳解_React
- 2022-05-20 Maven的配置及使用
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支