成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

基礎一:JS數(shù)據(jù)類型

codecook / 2233人閱讀

摘要:本文章主要總結一下數(shù)據(jù)類型的識別判斷方法最后封裝一個函數(shù),可以判別所有的類型數(shù)據(jù)類型基本類型類型該類型只有一個值,即小寫,在使用聲明變量但是未對其加以初始化時,這個變量的值就是。

*本文章主要總結一下js數(shù)據(jù)類型的識別判斷方法
tyoeof
instanceof
Object.prototype.toString.call
constructor
最后封裝一個函數(shù),可以判別所有的類型*

1.數(shù)據(jù)類型

基本類型:

Undefined類型:該類型只有一個值,即undefined(小寫),在使用var聲明變量但是未對其加以初始化時,這個變量的值就是undefined。

Null類型:該類型也只有一個值,即null(小寫),null值表示一個空對象指針,所以用typeof操作符檢測null值會返回object的原因。

Boolean類型:改類型有兩個值:true和false(小寫)

Number類型:表示整數(shù)和浮點數(shù)

String類型:即字符串

引用類型

Object類型:即對象

Array類型:數(shù)組

Date類型:日期

RegExp類型:正則

Function類型

2.類型的識別的判斷方法 (1)typeof總結:

首先typeof不是方法,只是一個操作符。

可以識別標準類型(Null除外

不能識別具體的對象類型(Function除外

返回的值首字母都是小寫?。。。。。。?!

    //識別標準類型
        typeof "jerry";      //"string"
        typeof 12;           //"number"
        typeof true;         //"boolean"
        typeof undefined;   //"undefined"
        typeof null;         //"object"
        typeof {name:"jerry"};   //"object"
        
    //識別引用類型
        typeof function(){};  //"function"
        typeof [];            //"object"
        typeof new Date;     //"object"
        typeof /d/;         //"object"
        //創(chuàng)建一個自定義對象
        function Person(){};
        typeof new Person;      //"object"
(2)instanceof
    //能夠判別引用類型
    [] instanceof Array;       //true
    /d/ instanceof RegExp;    //true
    new Date instanceof Date;  //true
    var a = function(){}; 
    a instanceof Function;     //true
   
    //不能判別原始類型
    1 instanceof Number;          //false
    "jerry" instanceof String;  //false
    
    //能夠判別自定義對象類型及父子類型
    //自定義類型
    function Person(){};
    Person instanceof Function;  //true
    //父子類型
    function Point(x,y){
        this.x = x;
        this.y = y;
    }
    function Cirele(x,y,r){
        Point.call(this,x,y);
        this.radius = r;
    }
    Circle.prototype = new Point();
    Circle.prototype.constructor = Circle;
    var c = new Circle(1,1,2);
    c instanceof Circle  //true
    c instanceof Point  //true

結論

可以判別內置對象類型

不能判別原始類型

判別自定義對象類型

結合1和3,用instanceof可以識別所有的對象類型

(3)Object.prototype.toString.call
    Object.prototype.toString.call("123");    //"[object String]"
    
    //封裝函數(shù),并做截取
    function type(obj){
        return Object.prototype.toString.call(obj).slice(8,-1);
    }
    //測試
    type("123");  //"String"
    
    //自定義類型
    function Point(x,y){
        this.x = x;
        this.y = y;
    }
    //測試
    type(new Point(1,2));       //"Object"

結論:

上述封裝的函數(shù)可以識別基本類型以及引用對象類型

不能識別自定義對象類型

(4)constructor(構造這個對象的構造函數(shù)的本身)
    //判斷基本類型(基本類型也有構造函數(shù));但是null和undefined除外,它倆沒有構造函數(shù)
    "jerry".constructor === String;  //true
    (1).constructor ===Number;        //true
    
    //判斷引用類型
    new Date().constructor === Date;  //true
    [].constructor === Array;   //true
    
    //判斷自定義對象
    function Person(name){
        this.name = name;
    }
    new Person("jerry").constructor === Person; //true
    
    //對constructor判別進行方法的封裝
    function getConstructorName(obj){
        return (obj===undefined||obj===null)?obj:        
           (obj.constructor && obj.constructor.toString().match(/functions*([^(]*)/)[1]);
    }

封裝的原理:

obj:假如傳入的參數(shù)是null或者undefined,沒有構造函數(shù)直接返回

obj.constructor如果存在執(zhí)行&&后面的語句

obj.constructor.toString():將類型對應的構造函數(shù)轉化成字符串 "Function Number(){code...}"

math(/functions*([^(]*)/)[1]:匹配構造函數(shù)的名稱,正則匹配

結論:

判別基本類型(Undefined/Null除外)

判別引用類型

判別自定義對象類型

結論:所以可以封裝一個函數(shù)getConstructorName判斷所有類型,但是這個函數(shù)返回的除了null和undefined是小寫之外,其他的首字母都是大寫。

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/79936.html

相關文章

  • Js基礎知識() - 變量

    摘要:內置函數(shù)和對象中內置了一些函數(shù)和對象,很多語言都會有內置的方法,直接可以調用開發(fā)。根據(jù)語法標準提供的內置函數(shù)包括和。注意基礎語法提供的內置函數(shù)和方法只有這些,像那是瀏覽器提供給我們的。強制類型轉換大家應該都知道。 js基礎 - 變量 *大家對js一定不會陌生,入門很簡單(普通入門),很多人通過網(wǎng)絡資源、書籍、課堂等很多途徑學習js,但是有些js基礎的只是往往被大家遺漏,本章就從js變量...

    leone 評論0 收藏0
  • Js基礎知識() - 變量

    摘要:內置函數(shù)和對象中內置了一些函數(shù)和對象,很多語言都會有內置的方法,直接可以調用開發(fā)。根據(jù)語法標準提供的內置函數(shù)包括和。注意基礎語法提供的內置函數(shù)和方法只有這些,像那是瀏覽器提供給我們的。強制類型轉換大家應該都知道。 js基礎 - 變量 *大家對js一定不會陌生,入門很簡單(普通入門),很多人通過網(wǎng)絡資源、書籍、課堂等很多途徑學習js,但是有些js基礎的只是往往被大家遺漏,本章就從js變量...

    MageekChiu 評論0 收藏0
  • 前端基礎進階():內存空間詳細圖解

    摘要:一棧數(shù)據(jù)結構與不同,中并沒有嚴格意義上區(qū)分棧內存與堆內存。引用數(shù)據(jù)類型的值是保存在堆內存中的對象。不允許直接訪問堆內存中的位置,因此我們不能直接操作對象的堆內存空間。為了更好的搞懂變量對象與堆內存,我們可以結合以下例子與圖解進行理解。 showImg(https://segmentfault.com/img/remote/1460000009784102?w=1240&h=683); ...

    _Suqin 評論0 收藏0
  • 基礎數(shù)據(jù)結構及js數(shù)據(jù)存儲

    摘要:引用數(shù)據(jù)類型及堆內存引用數(shù)據(jù)類型是保存在堆內存中的對象,他的大小是不固定的?;A數(shù)據(jù)類型在變量對象里可以直接對應對應的值,而引用數(shù)據(jù)類型是存儲在堆里的,在變量對象中對應的是堆內存的地址。因為我們修改本質上是修改了堆內存里的數(shù)據(jù)。 ? ??? ??因為以前前端開發(fā)跟數(shù)據(jù)存儲打交道比較少,javascript又具有自動垃圾回收機制。數(shù)據(jù)結構以及存儲相關的概念,其實是很容易被前端er忽略的。...

    Brenner 評論0 收藏0
  • 【連載】前端個人文章整理-從基礎到入門

    摘要:個人前端文章整理從最開始萌生寫文章的想法,到著手開始寫,再到現(xiàn)在已經(jīng)一年的時間了,由于工作比較忙,更新緩慢,后面還是會繼更新,現(xiàn)將已經(jīng)寫好的文章整理一個目錄,方便更多的小伙伴去學習。 showImg(https://segmentfault.com/img/remote/1460000017490740?w=1920&h=1080); 個人前端文章整理 從最開始萌生寫文章的想法,到著手...

    madthumb 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<