亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript中的數據類型檢測方法詳解

2019-11-19 11:04:05
字體:
來源:轉載
供稿:網友

本文實例講述了javascript中的數據類型檢測方法。分享給大家供大家參考,具體如下:

在javascript中數據類型

值類型: 布爾(Boolean),數值(Number),字符(String),空(Null),未定義(Undefined)

引用類型: 對象(Object),函數(Function),數組(Array),日期(Date),正則(RegExp)等等。

檢測方式之 typeof

console.log(typeof undefined)//'undefined'console.log(typeof null) // objectconsole.log(typeof true) //'boolean'console.log(typeof 123) //'number'console.log(typeof NaN) //'number'console.log(typeof "abc") //'string'console.log(typeof function() {}) //'function'var arr=[];console.log(typeof {}) //'object'console.log(typeof arr)//'object'

從上面可以看出來用 typeof 來檢測,不嚴謹。

null 被檢測成為了 object,  null 值表示一個空對象指針,用typeof操作符檢測null值時會返回object的原因, 這是在設計ECMAscript時候存在的一些bug。

同樣是js不嚴謹的一種表現形式。而數組也被檢測成為了一個對象, 所以用這種方式不嚴謹。

檢測方式之 toString.call()

console.log(toString.call(undefined) ) // '[object Window]''console.log(toString.call(null) ) // '[object Window]'console.log(toString.call(true) ) // '[object Boolean]'console.log(toString.call(123) ) // '[object Number]'console.log(toString.call(NaN) ) // '[object Number]'console.log(toString.call("abc") ) // '[object String]'console.log(toString.call(function() {})) // '[object Function]'var arr=[];console.log(toString.call({}) ) // '[object Object]'console.log(toString.call(arr) ) // '[object Array]'

可以看出來出了undefined和null 這兩個,其他的檢測都還是比較嚴謹的。

其中toString()函數是window的一個不可枚舉函數,繼承自Object

還可以寫成這樣:

window.toString.call('hello'); // "[object String]"Object.prototype.toString.call('hello'); // "[object String]"

檢測方式之 constructor

console.log('haha'.constructor == String); // trueconsole.log([].constructor === Array); // trueconsole.log({}.constructor === Object); // trueconsole.log(true.constructor === Boolean); // truevar a = 111; // 此處必須要用變量來代表數字,不然會報錯,從這也能看出來js是一門不嚴謹的語言console.log(a.constructor === Number); // true

我們通過把實例的構造函數指向其他地方,來改變它的constructor,就不安全了,不推薦使用 如下代碼所示:

var AAA = function(){}; // 定義一個AAA對象AAA.prototype = { say:function() {  alert('hello'); }}var arr1 = new Array(); // 定義一個數組arr1.constructor = function AAA(){}; // 這里可以改變實例的constructor。arr1.__proto__ = AAA.prototype; // 此處改變了原型鏈console.log(arr1.constructor); // AAAconsole.log(arr1 instanceof AAA); // true 原型鏈已經改變,arr1 已經不屬于Array了。console.log(arr1 instanceof Array); // false// 下面我們來讓AAA的原型鏈連到 Array上AAA.prototype.__proto__ = Array.prototype;console.log(arr1 instanceof Array); // true

檢測方式之 instanceof

檢測是否是某一對象的實例

console.log([] instanceof Array); // trueconsole.log({} instanceof Object); // trueconsole.log('haha' instanceof String); // falseconsole.log(true instanceof Boolean); // falseconsole.log(1 instanceof Number); // false

前面兩個是true,后面的全是false 說明了用 A instanceof B 來檢測的前提條件必須是A,B都為對象,通過下面的方式就可以看出來了

var a = new Number(1);var b = new String('haha');var t = new Boolean(true);console.log(a instanceof Number); // trueconsole.log(b instanceof String); // trueconsole.log(t instanceof Boolean); // true

此種方式也不安全,后面會有闡述,有關instanceof 和 isPrototypeOf的區別,我們以后再來探討

還有一種is的方式比如:Array.isArray() 專門用來檢測數組

console.log(Array.isArray([])); // true

這個有兼容問題,IE8及其以下版本瀏覽器不被支持

而jQuery里面也給我們提供了一些解決方案

jQuery.isArray():是否為數組。jQuery.isEmptyObject():是否為空對象(不含可枚舉的屬性)。jQuery.isFunction():是否為函數。jQuery.isNumeric():是否為數字。jQuery.isPlainObject():是否為使用“{}”或“new Object”生成的對象,而不是瀏覽器原生提供的對象。jQuery.isWindow():是否為window對象。jQuery.isXMLDoc():判斷一個DOM節點是否處于XML文檔之中。

總結

通過以上幾種方式,我們知道在不同的時候用不同的檢測方式,是一種有效的解決方案。

拓展

在number類型中,還有一種檢測是有窮數字的方法叫 isFinite(), 比如任何數字除以0,都為無窮大。Infinity,-Infinity,非數字都會被判為false

console.log(3/0); // Infinityconsole.log(-3/0); // -Infinityconsole.log(isFinite(3/0)); // falseconsole.log(isFinite(-3/0)); // falseconsole.log(isFinite(NaN)); // falseconsole.log(isFinite('haha')); // falseconsole.log(isFinite(true)); // true 在這里 true 被轉換成了數字 1console.log(isFinite(false)); // true 在這里 false 被轉換成了數字 0

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具http://tools.VeVB.COm/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容可查看本站專題:《JavaScript操作DOM技巧總結》、《JavaScript頁面元素操作技巧總結》、《JavaScript事件相關操作與技巧大全》、《JavaScript查找算法技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript錯誤與調試技巧總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久91亚洲精品中文字幕| 欧美人与性动交a欧美精品| 国产精品高潮呻吟视频| 永久免费精品影视网站| 成人在线播放av| 久久天天躁狠狠躁夜夜av| 久久精品亚洲热| 国产伦精品一区二区三区精品视频| 热re99久久精品国产66热| 中文字幕欧美日韩在线| 一区二区在线视频| 色爱av美腿丝袜综合粉嫩av| 97精品在线视频| 日韩欧美在线视频观看| 亚洲精品在线看| 色综合老司机第九色激情| 两个人的视频www国产精品| 日本人成精品视频在线| 亚洲精品日韩欧美| 亚洲日本中文字幕免费在线不卡| 性欧美视频videos6一9| 国产91在线播放| 亚洲视频在线观看| 日韩成人av网| 亚洲片国产一区一级在线观看| 韩剧1988免费观看全集| 久久久久国产精品一区| 亚洲精品99999| 欧美丰满老妇厨房牲生活| 美日韩丰满少妇在线观看| 热99精品只有里视频精品| 欧美亚洲一区在线| 久久久999精品视频| 亚洲一区二区三区四区视频| 91精品在线一区| www.日韩不卡电影av| 国产高清视频一区三区| 91影院在线免费观看视频| 欧美一级片久久久久久久| 欧美激情伊人电影| 国产精品美女视频网站| 亚洲综合最新在线| 在线观看日韩av| 亚洲香蕉av在线一区二区三区| 日韩视频在线免费观看| 亚洲黄在线观看| 久久精品国产91精品亚洲| 成人伊人精品色xxxx视频| 国产精品女人久久久久久| 18一19gay欧美视频网站| 久久久久久久国产精品| 精品激情国产视频| 亚洲人成欧美中文字幕| 亚洲天堂男人的天堂| 久久久免费高清电视剧观看| 欧美成人午夜激情视频| 欧美成人自拍视频| 欧洲日韩成人av| 欧美视频二区36p| 97在线观看免费高清| 蜜月aⅴ免费一区二区三区| 日韩精品中文字| 日韩经典中文字幕在线观看| 美女av一区二区| 国产精品一区二区三区成人| 97色在线视频观看| 91社区国产高清| 亚洲人成亚洲人成在线观看| 播播国产欧美激情| 国产精品户外野外| 日韩欧美在线视频免费观看| 欧美在线播放视频| 亚洲欧美精品一区二区| 亚洲尤物视频网| 国产美女精品视频| 亚洲一区二区三区sesese| 亚洲美女av黄| 日韩在线观看网站| 亚洲四色影视在线观看| 日本精品视频网站| 欧美日韩成人精品| 欧美成人网在线| 亚洲人成电影在线观看天堂色| 亚洲成人激情小说| 精品日本美女福利在线观看| 成人久久精品视频| 欧美激情精品在线| 亚洲男人天堂视频| 欧美丰满片xxx777| 精品日本美女福利在线观看| 亚洲娇小xxxx欧美娇小| 国产精品吴梦梦| 国产精品视频久久久| 欧美日韩视频免费播放| 久久久999国产| 日韩成人性视频| 日韩亚洲欧美中文高清在线| 91精品国产高清自在线| 亚洲精品乱码久久久久久按摩观| 久久精品国产99国产精品澳门| 成人字幕网zmw| 欧美肥婆姓交大片| 国产成人一区二区三区| 日韩在线观看网址| 亚洲国产精品人久久电影| 欧美日韩性视频| 亚洲第一天堂无码专区| 亚洲精品一区二区在线| 欧美日韩精品在线播放| 欧美日韩国产中文精品字幕自在自线| 国产视频欧美视频| 日av在线播放中文不卡| 亚洲男人天堂网站| 狠狠躁夜夜躁久久躁别揉| 国产一区二区三区四区福利| 久久视频免费观看| 久久精品一偷一偷国产| 国产一区二区三区日韩欧美| 国产精品欧美日韩一区二区| 亚洲精品狠狠操| 欧美性视频网站| 国产精品无码专区在线观看| 国产黑人绿帽在线第一区| 久久久人成影片一区二区三区观看| 欧美高清第一页| www.欧美三级电影.com| 一区二区三区天堂av| 91久热免费在线视频| 69视频在线播放| 精品久久久香蕉免费精品视频| 国产精品免费一区| 亚洲成人三级在线| 国产情人节一区| 中文字幕9999| 亚洲福利在线视频| 国产原创欧美精品| 激情av一区二区| 国产精品久久久久av免费| 亚洲最大的av网站| 97色在线观看免费视频| 亚洲国产欧美精品| 欧美日韩第一页| 91热福利电影| 欧洲午夜精品久久久| 亚洲少妇中文在线| 亚洲第一天堂无码专区| 亚洲视频在线观看网站| 日韩欧美综合在线视频| 国产精品国模在线| 亚洲国产精品yw在线观看| 成人免费视频97| 日韩av理论片| 亚洲精品福利免费在线观看| 国产精品99久久久久久久久久久久| 国产精品精品一区二区三区午夜版| 国产精品爽爽ⅴa在线观看| 亚洲精品国产精品乱码不99按摩| 亚洲成年人影院在线| 久久琪琪电影院| 欧美精品videossex88| 久久免费视频网| 激情成人在线视频| 欧美性猛交xxxx乱大交3| 91亚洲一区精品|