摘要:當完成訪問后,這個臨時對象會被銷毀掉。對于判斷對象類型的話,常用返回適合基本類型及檢測,遇到失效。通過拿到,適合內置對象和基元類型,遇到和失效等返回。
轉載請注明出處
原文連接 http://blog.huanghanlian.com/article/5b698e54b8ea642ea9213f49
數據類型JavaScript六種數據類型
JavaScript一共有六種數據類型,其中有五種原始類型,和一種對象類型。
JavaScript 隱式轉換
var x="The answer"+42;//The answer42 var y=42+"The answer";//42The answer
這里的加號可以理解為字符串的拼接
var x="37"-7; //30 var y="37"+7; //377
這里的減號會理解為減法運算,而加號會理解為字符串拼接
等于判斷
var x="1.23"==1.23;//true 當等于一邊是字符串一邊是數字的時候會嘗試把字符串轉換為數字再進行比較 var y=0==false;//true var e=null==undefined;//true var c=new Object()==new Object();//false var d=[1,2]==[1,2];//false
類型不同,嘗試類型轉換和比較
類型不同,嘗試類型轉換和比較:
null == undefined 相等
number == string 轉number 1 == “1.0" // true
boolean == ? 轉number 1 == true // true
object == number | string 嘗試對象轉為基本類型 new String("hi") == ‘hi’ // true
其它:false
嚴格等于
a===b
顧名思義,它首先會判斷等號兩邊的類型,如果兩邊類型不同,返回false
如果類型相同,
類型相同,同===
var h=null===null;//true var f=undefined===undefined;//true var g=NaN===NaN;//false number類型它和任何值比較都不會相等,包括和它自己 var l=new Object()===new Object();//false 對象應該用引用去比較,而不是用值去比較,因為它們不是完全相同的對象。所以我們定義對象x和y去比較只有這樣才會是true
JavaScript 包裝對象
原始類型number,string,boolean這三種原始類型都有對應的包裝類型。
var a = “string”; alert(a.length);//6 a.t = 3; alert(a.t);//undefined
字符串,當把一個基本類型嘗試以對象的方式去使用它的時候,比如訪問length屬性,js會很智能的把基本類型轉換為對應的包裝類型對象。相當于new了string。當完成訪問后,這個臨時對象會被銷毀掉。所以a.t賦值為3后再去輸出a.t值是undefined
JavaScript 類型檢測
類型檢測有以下幾種
typeof
instanceof
Object.prototype.toString
constructor
duck type
最常見的typeof它會返回一個字符串,非常適合函數對象和基本類型的判斷
typeof 100 === “number” typeof true === “boolean” typeof function () {} === “function” typeof(undefined) ) === “undefined” typeof(new Object() ) === “object” typeof( [1, 2] ) === “object” typeof(NaN ) === “number” typeof(null) === “object”
typeof判斷一些基本類型,函數對象的時候非常方便。但是對于其他對象的類型判斷就會沒有辦法了。比如說想判斷一個對象是不是數組,如果用typeof會返回object顯然不是我想要的。
對于判斷對象類型的話,常用obj instanceof Object
[1, 2] instanceof Array === true new Object() instanceof Array === false function person(){}; function student(){}; student.prototype=new person(); var bosn =new student(); console.log(bosn instanceof student)//true var one =new person(); console.log(one instanceof person)//true console.log(bosn instanceof person)//true
Object.prototype.toString
**IE6/7/8 Object.prototype.toString.apply(null) 返回”[object Object]”
**
Object.prototype.toString.apply([]); === “[object Array]”; Object.prototype.toString.apply(function(){}); === “[object Function]”; Object.prototype.toString.apply(null); === “[object Null]” Object.prototype.toString.apply(undefined); === “[object Undefined]”
typeof
適合基本類型及function檢測,遇到null失效。
[[Class]]
通過{}.toString拿到,適合內置對象和基元類型,遇到null和undefined失效(IE678等返回[object Object])。
instanceof
適合自定義對象,也可以用來檢測原生對象,在不同iframe和window間檢測時失效。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/83199.html
摘要:表達式是一種短語,可使解釋器用來產生一個值。權威指南運算符三元運算符值為就會返回冒號前面的值,如果是就會取冒號右邊的值。運算符運算符就是刪除對象上的屬性,變量,被刪除了。運算符運算符是一元運算符,不管值是多少都會返回 轉載請注明出處 原文連接 http://blog.huanghanlian.com/article/5b698e88b8ea642ea9213f4a 表達式和運算符 Ja...
摘要:全文為這些年,我曾閱讀深入理解過或正在閱讀學習即將閱讀的一些優秀經典前端后端書籍。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 全文為這些年,我曾閱讀、深入理解過(或正在閱讀學習、即將閱讀)的一些優秀經典前端/Java后端書籍。全文為純原創,且將持續更新,未經許可,不得進行轉載。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 基礎 基礎書籍 進階 進階階段,深入學習的書...
摘要:全文為這些年,我曾閱讀深入理解過或正在閱讀學習即將閱讀的一些優秀經典前端后端書籍。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 全文為這些年,我曾閱讀、深入理解過(或正在閱讀學習、即將閱讀)的一些優秀經典前端/Java后端書籍。全文為純原創,且將持續更新,未經許可,不得進行轉載。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 基礎 基礎書籍 進階 進階階段,深入學習的書...
摘要:全文為這些年,我曾閱讀深入理解過或正在閱讀學習即將閱讀的一些優秀經典前端后端書籍。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 全文為這些年,我曾閱讀、深入理解過(或正在閱讀學習、即將閱讀)的一些優秀經典前端/Java后端書籍。全文為純原創,且將持續更新,未經許可,不得進行轉載。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 基礎 基礎書籍 進階 進階階段,深入學習的書...
閱讀 3482·2021-09-06 15:13
閱讀 1531·2021-09-02 10:19
閱讀 2477·2019-08-30 15:52
閱讀 924·2019-08-29 15:25
閱讀 1570·2019-08-26 18:36
閱讀 499·2019-08-26 13:23
閱讀 1337·2019-08-26 10:46
閱讀 3505·2019-08-26 10:41