欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于javascript中的typeof和類型判斷(詳解)

 更新時間:2017年10月27日 08:20:09   作者:熊仔其人  
下面小編就為大家?guī)硪黄趈avascript中的typeof和類型判斷(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

typeof

ECMAScript 有 5 種原始類型(primitive type),即 Undefined、Null、Boolean、Number 和 String。我們都知道可以使用typeof運算符求得一個變量的類型,但是對引用類型變量卻只會返回object,也就是說typeof只能正確識別基本類型值變量。

var a = "abc";
console.log(typeof a); // "string"
var b = 123;
console.log(typeof b); // "number"
var c = true;
console.log(typeof c); // "boolean"
var d = null;
console.log(typeof d); // "object"
var f = undefined;
console.log(typeof f); // "undefined"
var g;
console.log(typeof g); // "undefined"

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

您也許會問,為什么 typeof 運算符對于 null 值會返回 "object"。這實際上是 JavaScript 最初實現(xiàn)中的一個錯誤,然后被 ECMAScript 沿用了?,F(xiàn)在,null 被認為是對象的占位符,從而解釋了這一矛盾,但從技術(shù)上來說,它仍然是原始值。

最后一個比較奇怪,typeof一個不存在的變量x居然返回了"object"而不是"undefined"。

我們在來如下代碼:

var a = function() { };
console.log(typeof a); // "function"
var b = [1,2,3]; 
console.log(typeof b); // "object"
var c = { };
console.log(typeof c); // "object"

對于數(shù)組和對象都返回"object",因此我們?nèi)粘i_發(fā)中一個常見需求就是如何判斷變量是數(shù)組還是對象。

類型判斷

類型判斷,一般就是判斷是否是數(shù)組,是否是空對象。這是針對這個需求,我日常用過或見過的判斷方法

判斷是否是數(shù)組

有數(shù)組:var a = [1,2,3,4,5];

方法一:

toString.call(a); // "[object Array]"方法二:

a instanceof Array; //true方法三:

a.constructor == Array; //true 第一種方法比較通用,也就是Object.prototype.toString.call(a)的簡寫。

instanceof和constructor判斷的變量,必須在當前頁面聲明的,比如,一個頁面(父頁面)有一個框架,框架中引用了一個頁面(子頁面),在子頁面中聲明了一個a,并將其賦值給父頁面的一個變量,這時判斷該變量,Array == object.constructor會返回false;

var a = [1,2,3,4,5];
console.log(toString.call(a)); // "[object Array]"      
console.log(a instanceof Array); //true
console.log(a.constructor == Array); //true

判斷是否是空對象

有變量:var obj = {};

方法一:

JSON.stringify(obj); // "{}"通過轉(zhuǎn)換成JSON對象來判斷是否是空大括號

方法二:

if(obj.id){ //如果屬性id存在....}這個方法比較土,大多數(shù)人都能想到,前提是得知道對象中有某個屬性。

方法三:

function isEmptyObject(e) { 
var t; for (t in e) return !1; return !0 } //trueisEmptyObject(obj);
//falseisEmptyObject({ "a":1, "b":2});

這個方法是jQuery的isEmptyObject()方法的實現(xiàn)方式。

以上這篇基于javascript中的typeof和類型判斷(詳解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Webpack 之 babel-loader文件預(yù)處理器詳解

    Webpack 之 babel-loader文件預(yù)處理器詳解

    這篇文章主要介紹了Webpack 之 babel-loader文件預(yù)處理器詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • 模仿百度三維地圖的js數(shù)據(jù)分享

    模仿百度三維地圖的js數(shù)據(jù)分享

    模仿百度三維地圖的js數(shù)據(jù),需要的朋友可以參考下。
    2011-05-05
  • 微信小程序頁面上下滾動效果

    微信小程序頁面上下滾動效果

    這篇文章主要為大家詳細介紹了微信小程序頁面上下滾動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • js實現(xiàn)分享到隨頁面滾動而滑動效果的方法

    js實現(xiàn)分享到隨頁面滾動而滑動效果的方法

    這篇文章主要介紹了js實現(xiàn)分享到隨頁面滾動而滑動效果的方法,實例分析了javascript操作頁面元素滾動效果的方法,需要的朋友可以參考下
    2015-04-04
  • tangram框架響應(yīng)式加載圖片方法

    tangram框架響應(yīng)式加載圖片方法

    這篇文章主要介紹了使用tangram框架響應(yīng)式加載圖片的方法,大家可以參考使用
    2013-11-11
  • JavaScript中的標簽語句用法分析

    JavaScript中的標簽語句用法分析

    這篇文章主要介紹了JavaScript中的標簽語句用法,實例分析了標簽語句的功能、定義及相關(guān)使用技巧,需要的朋友可以參考下
    2015-02-02
  • 原生JS實現(xiàn)各種運動之復(fù)合運動

    原生JS實現(xiàn)各種運動之復(fù)合運動

    這篇文章主要為大家詳細介紹了原生JS實現(xiàn)各種運動之復(fù)合運動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 使用微信SDK自定義分享的方法

    使用微信SDK自定義分享的方法

    這篇文章主要介紹了使用微信SDK自定義分享的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • 基于JavaScript實現(xiàn)電子簽名功能

    基于JavaScript實現(xiàn)電子簽名功能

    這篇文章主要為大家詳細介紹了如何通過JavaScript實現(xiàn)簡單的電子簽名功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-11-11
  • javascript實現(xiàn)的textarea運行框效果代碼 不用指定id批量指定

    javascript實現(xiàn)的textarea運行框效果代碼 不用指定id批量指定

    今天在寫一個網(wǎng)頁的時候用到了N多嵌套在textarea標簽里的代碼,定義雙擊運行其內(nèi)的代碼段。但是每次創(chuàng)建一個這樣的可運行的實例都要給textarea元素自定義一個id值和寫入雙擊事件,好不麻煩。
    2009-12-12

最新評論