一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - javascript基本類型詳解

javascript基本類型詳解

2021-04-27 16:38JavaScript教程網 JavaScript

本文介紹了javascript中的5個原始值(數字,字符,布爾,null,undefined),6個typeo能判斷(數字,字符,布爾,object,function,undefined)以及9個原生的內置構造函數,是篇非常不錯的文章,這里推薦給大家。

js中一共5個原始值,6個typeof能判斷的,9個原生的內置的構造函數。

  這569,構成了js語言的基礎。

   5個原始值是:數字,字符,布爾,null,undefined

   typeof能判斷:數字,字符,布爾,object,function,undefined。 注意null和數組,tyopeof都輸出object。

      typeof不能區分出數組和對象,如何判斷類型呢?使用Object.prototype.toString.apply()。

      if(value&&typeof value ==='object'&&value.constructor === Array)

     上面的檢測如果在不同幀和窗口創建的數組,會給出false,window對象不一樣了.

      可靠的方法是if(Object.prototype.toString.apply(value)==="[object  Array]")

    arguments 數組不是一個數組,他只是一個有著length成員屬性的對象。
   如下面例子所示 arguments不是普通的array

 

復制代碼 代碼如下:


var a = function (){
      var b = Object.prototype.toString.apply(arguments);
      console.log(b);

 

}
a();//輸出[object Arguments]

 

 

復制代碼 代碼如下:


var a = function (){
      var c = [];
      var b = Object.prototype.toString.apply(c);
      console.log(b);

 

}
a();//輸出[object Array]

 

instanceof是如何判斷是否實例

prototype里面的屬性有constructor.

默認的prototype屬性是一個object對象,可以設置為任何復雜值,忽略設置為原始值.

雖然他盡是一個對象,但他是特殊性的,圓形鏈將每個實例都鏈接至其構造函數的prototype屬性。實例與構造函數的 prototype屬性之間有一個隱蔽的鏈接,這就是實例的__proto__。同時實例的constructor屬性是通過構造函數prototype的constructor拿到的。

但是要保留constructor,這樣可以讓new的實例有constructor的屬性,也可以使用instanceof來判斷。

 

復制代碼 代碼如下:


var Foo = function(){}

 

Foo.prototype={constructor:Foo}

var FooInstance = new Foo;

FooInstance.__proto__=== Foo.prototype;//true

FooInstance.constructor === Foo; //true

 

實際上instanceof判斷不是依據constructor,而是依據原型鏈判斷,如下面例子

 

復制代碼 代碼如下:

 var Foo = function(){};
 Foo.prototype={};
 var FooInstance = {};
 FooInstance.__proto__=Foo.prototype;
 console.log(FooInstance instanceof Foo);//true

 

使用原始值,不使用構造函數

哪些值算是false:false,"",null,0,-0,NaN,undefined,這些算是false其他都是true

但是請注意下面這個例子

 

復制代碼 代碼如下:

    var a = Boolean(false);
        var b = new Boolean("");
        if (a ){console.log(a);}//無法輸出
        if (b ){console.log(b);}//Boolean {[[PrimitiveValue]]: false} new 一個相當于一個對象了,就不是false

 

上面的文章理論性稍強了一些,不過這些都是構成javascript語言的基礎,一定要了解清楚才行。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 女被男啪到哭 | 国产码一区二区三区 | 欧美一区二区日韩一区二区 | 青青草亚洲 | 成人xxxxxx| 99热精品国产麻豆 | 免费导航 | 国产真实伦对白在线播放 | pregnant欧美孕交xxx | 亚洲国产99999在线精品一区 | 免费被黄网站在观看 | jj视频免费看 | 91麻豆国产福利在线观看 | 7788理论片在线观看 | 成人香蕉xxxxxxx | 亚洲热在线视频 | 歪歪漫画a漫入口 | 国产偷窥 | 久久永久影院免费 | 手机看片自拍自自拍日韩免费 | 精品无人区麻豆乱码无限制 | 侵犯小男生免费视频网站 | 羞羞漫画免费漫画页面在线看漫画秋蝉 | 国产黄频在线观看高清免费 | 视频在线观看高清免费看 | 成人精品在线 | 好男人影视社区www在线观看 | 国产日日操 | 成人免费视频一区二区三区 | 热门小说同人h改编h | 久久爽狠狠添AV激情五月 | 欧美精品色精品一区二区三区 | 日韩欧美亚洲天堂 | 日韩妹妹 | 妹妹骑上来蹭着蹭着就射了 | 無码一区中文字幕少妇熟女H | 咪咪爱991| 美女跪式抽搐gif动态图 | 欧美精品一区二区在线观看播放 | 亚州精品视频 | 成人毛片高清视频观看 |