亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄 搜索
導(dǎo)論 前言 為什么學(xué)習(xí)JavaScript JavaScript的歷史 基本語(yǔ)法 語(yǔ)法概述 數(shù)值 字符串 對(duì)象 數(shù)組 函數(shù) 運(yùn)算符 數(shù)據(jù)類型轉(zhuǎn)換 錯(cuò)誤處理機(jī)制 JavaScript 編程風(fēng)格 標(biāo)準(zhǔn)庫(kù) Object對(duì)象 包裝對(duì)象和Boolean對(duì)象 Number對(duì)象 String對(duì)象 Math對(duì)象 Date對(duì)象 RegExp對(duì)象 JSON對(duì)象 ArrayBuffer:類型化數(shù)組 面向?qū)ο缶幊?/a> 概述 封裝 繼承 模塊化編程 DOM Node節(jié)點(diǎn) document節(jié)點(diǎn) Element對(duì)象 Text節(jié)點(diǎn)和DocumentFragment節(jié)點(diǎn) Event對(duì)象 CSS操作 Mutation Observer 瀏覽器對(duì)象 瀏覽器的JavaScript引擎 定時(shí)器 window對(duì)象 history對(duì)象 Ajax 同域限制和window.postMessage方法 Web Storage:瀏覽器端數(shù)據(jù)儲(chǔ)存機(jī)制 IndexedDB:瀏覽器端數(shù)據(jù)庫(kù) Web Notifications API Performance API 移動(dòng)設(shè)備API HTML網(wǎng)頁(yè)元素 Canvas API SVG 圖像 表單 文件和二進(jìn)制數(shù)據(jù)的操作 Web Worker 服務(wù)器發(fā)送事件 Page Visibility API Fullscreen API:全屏操作 Web Speech requestAnimationFrame WebSocket WebRTC Web Components HTML網(wǎng)頁(yè)的API HTML網(wǎng)頁(yè)元素 Canvas API SVG 圖像 表單 文件和二進(jìn)制數(shù)據(jù)的操作 Web Worker 服務(wù)器發(fā)送事件 Page Visibility API Fullscreen API:全屏操作 Web Speech requestAnimationFrame WebSocket WebRTC Web Components 開(kāi)發(fā)工具 console對(duì)象 PhantomJS Bower:客戶端庫(kù)管理工具 Grunt:任務(wù)自動(dòng)管理工具 Gulp:任務(wù)自動(dòng)管理工具 Browserify:瀏覽器加載Node.js模塊 RequireJS和AMD規(guī)范 Source Map JavaScript 程序測(cè)試 JavaScript高級(jí)語(yǔ)法 Promise對(duì)象 有限狀態(tài)機(jī) MVC框架與Backbone.js 嚴(yán)格模式 ECMAScript 6 介紹 附錄 JavaScript API列表
文字

    • 包裝對(duì)象

      • 定義

      • 包裝對(duì)象的構(gòu)造函數(shù)

      • 包裝對(duì)象實(shí)例的方法

      • 原始類型的自動(dòng)轉(zhuǎn)換

      • 自定義方法

    • Boolean對(duì)象

      • 概述

      • Boolean實(shí)例對(duì)象的布爾值

      • Boolean函數(shù)的類型轉(zhuǎn)換作用

包裝對(duì)象

定義

在JavaScript中,“一切皆對(duì)象”,數(shù)組和函數(shù)本質(zhì)上都是對(duì)象,就連三種原始類型的值——數(shù)值、字符串、布爾值——在一定條件下,也會(huì)自動(dòng)轉(zhuǎn)為對(duì)象,也就是原始類型的“包裝對(duì)象”。

所謂“包裝對(duì)象”,就是分別與數(shù)值、字符串、布爾值相對(duì)應(yīng)的Number、String、Boolean三個(gè)原生對(duì)象。這三個(gè)原生對(duì)象可以把原始類型的值變成(包裝成)對(duì)象。

var v1 = new Number(123);
var v2 = new String("abc");
var v3 = new Boolean(true);

上面代碼根據(jù)原始類型的值,生成了三個(gè)對(duì)象,與原始值的類型不同。這用typeof運(yùn)算符就可以看出來(lái)。

typeof v1 // "object"
typeof v2 // "object"
typeof v3 // "object"

v1 === 123 // false
v2 === "abc" // false
v3 === true // false

JavaScript設(shè)計(jì)包裝對(duì)象的最大目的,首先是使得JavaScript的“對(duì)象”涵蓋所有的值。其次,使得原始類型的值可以方便地調(diào)用特定方法。

包裝對(duì)象的構(gòu)造函數(shù)

Number、String和Boolean這三個(gè)原生對(duì)象,既可以當(dāng)作構(gòu)造函數(shù)使用(即加上new關(guān)鍵字,生成包裝對(duì)象實(shí)例),也可以當(dāng)作工具方法使用(即不加new關(guān)鍵字,直接調(diào)用),這相當(dāng)于生成實(shí)例后再調(diào)用valueOf方法,常常用于將任意類型的值轉(zhuǎn)為某種原始類型的值。

Number(123) // 123

String("abc") // "abc"

Boolean(true) // true

工具方法的詳細(xì)介紹參見(jiàn)第二章的《數(shù)據(jù)類型轉(zhuǎn)換》一節(jié)。

包裝對(duì)象實(shí)例的方法

包裝對(duì)象實(shí)例可以使用Object對(duì)象提供的原生方法,主要是 valueOf 方法和 toString 方法。

(1)valueOf方法

valueOf方法返回包裝對(duì)象實(shí)例對(duì)應(yīng)的原始類型的值。

new Number(123).valueOf()
// 123

new String("abc").valueOf()
// "abc"

new Boolean("true").valueOf()
// true

(2)toString方法

toString方法返回該實(shí)例對(duì)應(yīng)的原始類型值的字符串形式。

new Number(123).toString()
// "123"

new String("abc").toString()
// "abc"

new Boolean("true").toString()
// "true"

原始類型的自動(dòng)轉(zhuǎn)換

原始類型可以自動(dòng)調(diào)用定義在包裝對(duì)象上的方法和屬性。比如String對(duì)象的實(shí)例有一個(gè)length屬性,返回字符串的長(zhǎng)度。

var v = new String("abc");
v.length // 3

所有原始類型的字符串,都可以直接使用這個(gè)length屬性。

"abc".length
// 3

上面代碼對(duì)字符串a(chǎn)bc調(diào)用length屬性,實(shí)際上是將“字符串”自動(dòng)轉(zhuǎn)為String對(duì)象的實(shí)例,再在其上調(diào)用length屬性。這就叫原始類型的自動(dòng)轉(zhuǎn)換。

abc是一個(gè)字符串,屬于原始類型,本身不能調(diào)用任何方法和屬性。但當(dāng)對(duì)abc調(diào)用length屬性時(shí),JavaScript引擎自動(dòng)將abc轉(zhuǎn)化為一個(gè)包裝對(duì)象實(shí)例,然后再對(duì)這個(gè)實(shí)例調(diào)用length屬性,在得到返回值后,再自動(dòng)銷毀這個(gè)臨時(shí)生成的包裝對(duì)象實(shí)例。

這種原始類型值可以直接調(diào)用的方法還有很多(詳見(jiàn)后文對(duì)各包裝對(duì)象的介紹),除了前面介紹過(guò)的valueOf和stringOf方法,還包括三個(gè)包裝對(duì)象各自定義在實(shí)例上的方法。。

'abc'.charAt === String.prototype.charAt
// true

上面代碼表示,字符串a(chǎn)bc的charAt方法,實(shí)際上就是定義在String對(duì)象實(shí)例上的方法(關(guān)于prototype對(duì)象的介紹參見(jiàn)《面向?qū)ο缶幊獭芬徽拢?/p>

如果包裝對(duì)象與原始類型值進(jìn)行混合運(yùn)算,包裝對(duì)象會(huì)轉(zhuǎn)化為原始類型(實(shí)際是調(diào)用自身的valueOf方法)。

new Number(123) + 123// 246
new String("abc") + "abc"// "abcabc"

自定義方法

三種包裝對(duì)象還可以在原型上添加自定義方法和屬性,供原始類型的值直接調(diào)用。

比如,我們可以新增一個(gè)double方法,使得字符串和數(shù)字翻倍。

String.prototype.double = function (){
    return this.valueOf() + this.valueOf();
};

"abc".double()
// abcabc

Number.prototype.double = function (){
    return this.valueOf() + this.valueOf();
};

(123).double()
// 246

上面代碼在123外面必須要加上圓括號(hào),否則后面的點(diǎn)運(yùn)算符(.)會(huì)被解釋成小數(shù)點(diǎn)。

但是,這種自定義方法和屬性的機(jī)制,只能定義在包裝對(duì)象的原型上,如果直接對(duì)原始類型的變量添加屬性,則無(wú)效。

var s = "abc";
s.p = 123;
s.p // undefined

上面代碼直接對(duì)支付串a(chǎn)bc添加屬性,結(jié)果無(wú)效。

Boolean對(duì)象

概述

Boolean對(duì)象是JavaScript的三個(gè)包裝對(duì)象之一。作為構(gòu)造函數(shù),它主要用于生成布爾值的包裝對(duì)象的實(shí)例。

var b = new Boolean(true);
typeof b // "object"
b.valueOf() // true

上面代碼的變量b是一個(gè)Boolean對(duì)象的實(shí)例,它的類型是對(duì)象,值為布爾值true。這種寫(xiě)法太繁瑣,幾乎無(wú)人使用,直接對(duì)變量賦值更簡(jiǎn)單清晰。

var b = true;

Boolean實(shí)例對(duì)象的布爾值

特別要注意的是,所有對(duì)象的布爾運(yùn)算結(jié)果都是true。因此,false對(duì)應(yīng)的包裝對(duì)象實(shí)例,布爾運(yùn)算結(jié)果也是true。

if (new Boolean(false)) {
    console.log("true"); 
} // true

if (new Boolean(false).valueOf()) {
    console.log("true"); 
} // 無(wú)輸出

上面代碼的第一個(gè)例子之所以得到true,是因?yàn)閒alse對(duì)應(yīng)的包裝對(duì)象實(shí)例是一個(gè)對(duì)象,進(jìn)行邏輯運(yùn)算時(shí),被自動(dòng)轉(zhuǎn)化成布爾值true(所有對(duì)象對(duì)應(yīng)的布爾值都是true)。而實(shí)例的valueOf方法,則返回實(shí)例對(duì)應(yīng)的原始類型值,本例為false。

Boolean函數(shù)的類型轉(zhuǎn)換作用

Boolean對(duì)象除了可以作為構(gòu)造函數(shù),還可以單獨(dú)使用,將任意值轉(zhuǎn)為布爾值。這時(shí)Boolean就是一個(gè)單純的工具方法。

Boolean(undefined) // false
Boolean(null) // false
Boolean(0) // false
Boolean('') // false
Boolean(NaN) // false
Boolean(1) // true
Boolean('false') // true
Boolean([]) // true
Boolean({}) // true
Boolean(function(){}) // true
Boolean(/foo/) // true

上面代碼中幾種得到true的情況,都值得認(rèn)真記住。

使用not運(yùn)算符(!)也可以達(dá)到同樣效果。

!!undefined // false
!!null // false
!!0 // false
!!'' // false
!!NaN // false
!!1 // true
!!'false' // true
!![] // true
!!{} // true
!!function(){} // true
!!/foo/ // true

綜上所述,如果要獲得一個(gè)變量對(duì)應(yīng)的布爾值,有多種寫(xiě)法。

var a = "hello world";

new Boolean(a).valueOf() // true
Boolean(a) // true
!!a // true

最后,對(duì)于一些特殊值,Boolean對(duì)象前面加不加new,會(huì)得到完全相反的結(jié)果,必須小心。

if (Boolean(false)) 
        console.log('true'); // 無(wú)輸出

if (new Boolean(false))
        console.log('true'); // true

if (Boolean(null)) 
        console.log('true'); // 無(wú)輸出

if (new Boolean(null))
        console.log('true'); // true


上一篇: 下一篇: