国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

avaScript 精粹 基礎 進階(1)數據類型

blankyao / 341人閱讀

摘要:當完成訪問后,這個臨時對象會被銷毀掉。對于判斷對象類型的話,常用返回適合基本類型及檢測,遇到失效。通過拿到,適合內置對象和基元類型,遇到和失效等返回。

轉載請注明出處

原文連接 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 包裝對象

原始類型numberstringboolean這三種原始類型都有對應的包裝類型。

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

相關文章

  • JavaScript 精粹 基礎 進階(2)表達式和運算符

    摘要:表達式是一種短語,可使解釋器用來產生一個值。權威指南運算符三元運算符值為就會返回冒號前面的值,如果是就會取冒號右邊的值。運算符運算符就是刪除對象上的屬性,變量,被刪除了。運算符運算符是一元運算符,不管值是多少都會返回 轉載請注明出處 原文連接 http://blog.huanghanlian.com/article/5b698e88b8ea642ea9213f4a 表達式和運算符 Ja...

    beanlam 評論0 收藏0
  • 那些年,我的前端/Java后端書單

    摘要:全文為這些年,我曾閱讀深入理解過或正在閱讀學習即將閱讀的一些優秀經典前端后端書籍。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 全文為這些年,我曾閱讀、深入理解過(或正在閱讀學習、即將閱讀)的一些優秀經典前端/Java后端書籍。全文為純原創,且將持續更新,未經許可,不得進行轉載。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 基礎 基礎書籍 進階 進階階段,深入學習的書...

    fxp 評論0 收藏0
  • 那些年,我的前端/Java后端書單

    摘要:全文為這些年,我曾閱讀深入理解過或正在閱讀學習即將閱讀的一些優秀經典前端后端書籍。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 全文為這些年,我曾閱讀、深入理解過(或正在閱讀學習、即將閱讀)的一些優秀經典前端/Java后端書籍。全文為純原創,且將持續更新,未經許可,不得進行轉載。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 基礎 基礎書籍 進階 進階階段,深入學習的書...

    Tecode 評論0 收藏0
  • 那些年,我的前端/Java后端書單

    摘要:全文為這些年,我曾閱讀深入理解過或正在閱讀學習即將閱讀的一些優秀經典前端后端書籍。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 全文為這些年,我曾閱讀、深入理解過(或正在閱讀學習、即將閱讀)的一些優秀經典前端/Java后端書籍。全文為純原創,且將持續更新,未經許可,不得進行轉載。當然,如果您喜歡這篇文章,可以動手點點贊或者收藏。 基礎 基礎書籍 進階 進階階段,深入學習的書...

    VPointer 評論0 收藏0

發表評論

0條評論

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