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

資訊專欄INFORMATION COLUMN

閑話JavaScript數據類型

jerryloveemily / 1583人閱讀

摘要:支持的類型的內置數據類型羅列如下自定義自定義這三種類型的賦值是同類似的。這根不同,這因為是沒有包裝類新增的基本類型,只支持函數式賦值,不支持字面量和函數構造。

JavaScript支持的類型

JS的內置數據類型羅列如下:

undefined
null
bool
number
string
function
object
    Function
        Date
        Error
        自定義function
    new Function
    new Date
    new Error
    new 自定義function
symbol
bool, number, string

bool, number, string這三種類型的賦值是同類似的。

字面量方式賦值
var b = true;
var n = 10;
var s = "hello";
函數式賦值

與字面量方式等價的函數式賦值

var b = Boolean(true);
var n = Number(10);
var s = String("hello");

可驗證變量的類型:

typeof b; // "bool"
typeof n; // "number"
typeof s; // "string"
基本類型包裝類

倘若透過基本類型包裝類構造,那么這些變量都變成object類型了。

var obj_b = new Boolean(true);
var obj_n = new Number(10);
var obj_s = new String("hello");

typeof obj_b; // "object"
typeof obj_n; // "object"
typeof obj_s; // "object"

基本類型包裝類實例(obj_b, obj_n, obj_s)可認為是基本類型字面量(b, n, s),由值類型被封裝成了一個引用類型,二者之間可以做比較的。

obj_b.valueOf() == b  //true
obj_n.valueOf() == n  //true
obj_s.valueOf() == s  //true

看來基本類型包裝類(Number, Boolean, String)即能當函數直接調用,也能做構造方法,這正是JS函數的魔法。這里自定義一個函數MyNumber, 模仿Number的實現。

function MyNumber(value) {
    var _self = this;
    // 如果是new構造出來的
    if (_self instanceof MyNumber) {
        _self.value = value;
        return _self;
    }
    return parseFloat(value);
}

MyNumber.prototype.valueOf = function() {
    return parseFloat(this.value);
}

MyNumber.prototype.doubledValue = function() {
    return this.valueOf() * 2;
}

var mnum = MyNumber("12abc");
console.log(mnum);       // 12
console.log(typeof mnum);// number

var obj_mnum = new MyNumber("12abc");
console.log(obj_mnum);  // { [Number: 12] value: "12abc" }
console.log(+obj_mnum); // 12. +用來轉化為number類型,所以返回.valueOf()的結果
console.log(typeof obj_mnum);        // object
console.log(obj_mnum.doubledValue()) //24

若不用new,也可用Object.create(..prototype),二者等價。

var obj_mnum = Object.create(MyNumber.prototype);
MyNumber.call(obj_mnum, "12abc")

console.log(obj_mnum);  // { [Number: 12] value: "12abc" }
console.log(+obj_mnum); // 12. +用來轉化為number類型,所以返回.valueOf()的結果
console.log(typeof obj_mnum);        // object
console.log(obj_mnum.doubledValue()) //24
基本類型字面量和基本類型包裝類實例的關系

二者之間可以做算數運算:

obj_n + n //20
// 過程: obj_n是引用類型 
//       ->通過調用其valueOf()轉為值類型10 
//       -> 10 + 10 = 20

obj_b + obj_n // 11
// 過程:obj_b引用類型
//      -> 調用valueOf()轉為值類型true
//      -> 布爾true需要轉為number類型做算數運算,調用Number(true),得到1
//      obj_n引用類型 -> 轉為值類型 10
//      所以 1 + 10 = 11

關于JS數據類型轉換詳情,請看Javascript中的類型轉換

基本類型何以能調用方法

嚴格來講,基本類型字面量是不能調用任何方法的。但是"hello".length會成功返回5. 這因為JS解釋器在執行這句代碼時,會生成一個臨時的基本類型包裝類的實例,并調用其length。執行完后,就銷毀了這個臨時變量。

var tmp = new String("hello");
tmp.length
undefined 和 null

變量聲明而不賦值,其值就是undefined

var a;
a === undefined; //true. a 嚴格等于 undefined
typeof a;        // "undefined"

若賦值為null:

var a = null;
a === null;      // true
a === undefined; // false, a 不再嚴格等于undefined
typeof a;        // "object"

可理解為,null是有值的,特殊的空值;而undfined是表示無值。

undefined 和 null的一些區別

1.. JSON.stringify會序列化null值,但不會序列化undefined

    var obj = {name: "tom", age: null}
    JSON.stringify(obj) // "{"name":"tom","age":null}"
    
    var obj = {name: "tom", age: undefined} //"{"name":"tom"}"
對象實例的字段聲明為undefined,是無意義的。

2.. undefined會觸發ES6的default value,而null不會。

    function greet(name="world") {
        console.log("hello", name)
    }
    greet()          //hello world
    greet(undefined) //hello world
    greet(null)      //hello null

這里也進一步印證了, null本身是有值的,不過是個特殊的空值。而undefined是無值的。

值得一提的是,基本類型undefined/null是沒有任何方法的,也不能夠調用其任何方法。這根bool/number/string不同,這因為是undefined/null沒有包裝類

symbol

ES6新增的基本類型,只支持函數式賦值,不支持字面量和函數構造。

var sim = Symbol("IBM") // ok
sim                     // Symbol("IBM")
typeof sim              // "symbol"
sim = new Symbol("IBM") // TypeError: Symbol is not a constructor
function 和 Function

JS函數可以通過new Function構造,但通常用function關鍵字定義。二者的關聯,已在獨家解析Javascript原型繼承 - 之函數原型和AOP有詳細的闡述。這里就簡要說明下,函數本身和函數構造實例的一點區別。

type of Date // function. Date本身是函數
typeof new Date() // object. 通過new Date構造出來的是object實例
new Date().__proto__ == Date.prototype //true. 
// new Date()既然是由Date函數構造出來的,
// 所以new Date()的run-time? __proto__就是Date的design-time的prototype

// new Date()就是Date的構造實例了
new Date() instanceof Date // true. 

關于 run-time __proto__和design-time prototype,請讀者參考獨家解析Javascript原型繼承

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

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/84057.html

相關文章

  • 2017-07-17 前端日報

    摘要:前端日報精選聽說你沒來總結個人使用過的移動端布局方法新特性簡介用寫組件坦然面對應對前端疲勞中文深入理解筆記函數前端架構經驗分享系列教程之創建頁面元素龍云全棧系列教程之定位頁面元素龍云全棧第期與表單驗證技術周刊期知乎 2017-07-17 前端日報 精選 聽說你沒來 JSConf 2017?總結個人使用過的移動端布局方法 - Rni-L - SegmentFaultNode.js v8....

    caiyongji 評論0 收藏0
  • JavaScript 編程精解 中文第三版 十一、異步編程

    摘要:回調異步編程的一種方法是使執行慢動作的函數接受額外的參數,即回調函數。執行異步工作的函數通常會在完成工作之前返回,安排回調函數在完成時調用。它注冊了一個回調函數,當解析并產生一個值時被調用。 來源:ApacheCN『JavaScript 編程精解 中文第三版』翻譯項目原文:Asynchronous Programming 譯者:飛龍 協議:CC BY-NC-SA 4.0 自豪地采用谷歌...

    GeekQiaQia 評論0 收藏0
  • HTML+CSS+JAVASCRIPT 高仿低配網頁版網易云音樂播放器

    摘要:高仿低配網頁版網易云音樂播放器前言沒有使用任何框架,只是想用最簡單純的代碼實現下前臺后臺是參考網上的例子寫的,代碼是在的基礎上重新寫的還有她的姊妹篇網易云音樂移動端,請查看這里寫在前頭的話鄙人野生前端一只,專業,自學前端已經一年多了 HTML+CSS+JAVASCRIPT 高仿低配網頁版網易云音樂播放器 showImg(https://segmentfault.com/img/remo...

    RaoMeng 評論0 收藏0
  • HTML+CSS+JAVASCRIPT 高仿低配網頁版網易云音樂播放器

    摘要:高仿低配網頁版網易云音樂播放器前言沒有使用任何框架,只是想用最簡單純的代碼實現下前臺后臺是參考網上的例子寫的,代碼是在的基礎上重新寫的還有她的姊妹篇網易云音樂移動端,請查看這里寫在前頭的話鄙人野生前端一只,專業,自學前端已經一年多了 HTML+CSS+JAVASCRIPT 高仿低配網頁版網易云音樂播放器 showImg(https://segmentfault.com/img/remo...

    sean 評論0 收藏0

發表評論

0條評論

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