摘要:中這樣描述和調(diào)用方法用來把對(duì)象轉(zhuǎn)換成原始類型的值數(shù)值字符串和布爾值。你很少需要自己調(diào)用此函數(shù)當(dāng)遇到一種需要轉(zhuǎn)換成一個(gè)原始值情況時(shí)候,會(huì)自動(dòng)調(diào)用此函數(shù)。默認(rèn)情況下會(huì)被每個(gè)對(duì)象繼承。
MDN 中這樣描述 valueOf() 和 toString():
JavaScript 調(diào)用 valueOf() 方法用來把對(duì)象轉(zhuǎn)換成原始類型的值(數(shù)值、字符串和布爾值)。 你很少需要自己調(diào)用此函數(shù);當(dāng)遇到一種需要轉(zhuǎn)換成一個(gè)原始值情況時(shí)候, JavaScript 會(huì)自動(dòng)調(diào) 用此函數(shù)。 默認(rèn)情況下, valueOf() 會(huì)被每個(gè)對(duì)象Object繼承。每一個(gè)內(nèi)置對(duì)象都會(huì)覆蓋這個(gè)方法為了返回 一個(gè)合理的值,如果對(duì)象沒有原始值,valueOf() 就會(huì)返回對(duì)象自身; 每個(gè)對(duì)象都有一個(gè) toString() 方法,當(dāng)對(duì)象被表示為文本值時(shí)或者當(dāng)以期望字符串的方式引用 對(duì)象時(shí),該方法被自動(dòng)調(diào)用。默認(rèn)情況下,toString() 方法被每個(gè)繼承自O(shè)bject的對(duì)象繼承。如 果此方法在自定義對(duì)象中未被覆蓋,toString() 返回 "[object type]",其中type是對(duì)象類型
簡單的說:
valueOf()函數(shù)用于返回指定對(duì)象的原始值;
toString()函數(shù)用于返回指定對(duì)象的字符串;
對(duì)象 | valueOf() 返回值 | toString() 返回值 |
---|---|---|
Number | 數(shù)字值(number) | 數(shù)字值(string) |
String | 字符串值 | 字符串值 |
Boolean | 布爾值 | 字符串值 |
Object | 對(duì)象本身 | 字符串值 |
Function | 函數(shù)本身 | 字符串值 |
Date | 以毫秒數(shù)存儲(chǔ)的時(shí)間值(number) | 標(biāo)準(zhǔn)時(shí)間輸出(string) |
// Number var num = 15.26540, num2 = new Number(15.26540); console.log( "valueOf", num.valueOf() === num ); // true number類型 console.log( "toString", num.toString() === num );// false string類型 console.log( "valueOf", num2.valueOf() === num2 ); // false number類型 console.log( "toString", num2.toString() === num2 );// false string類型 console.log( num.valueOf() === num.toString());// false console.log( num2.valueOf() === num2.toString());// false // String var str = "abcd", str2 = new String("abcd"); console.log( "valueOf", str.valueOf() === str );// true string類型 console.log( "toString", str.toString() === str );// true string類型 console.log( "valueOf", str2.valueOf() === str2 );// false string類型 console.log( "toString", str2.toString() === str2 );// false string類型 console.log( str.valueOf() === str.toString());// true console.log( str2.valueOf() === str2.toString());// true // Boolean var bool = true, bool2 = new Boolean(true); console.log( "valueOf", bool.valueOf() === bool );// true string類型 console.log( "toString", bool.toString() === bool );// false string類型 console.log( "valueOf", bool2.valueOf() === bool2 );// false boolean類型 console.log( "toString", bool2.toString() === bool2 );// false string類型 console.log( bool.valueOf() === bool.toString());// false console.log( bool2.valueOf() === bool2.toString());// false // Object var obj = {name: "張三", age: 18}; console.log( "valueOf", obj.valueOf() === obj );// true object類型 console.log( "toString", obj.toString() === obj );// false string類型 console.log( obj.valueOf() === obj.toString());// false // Function var fn = function(){}, fn2 = new Function("x", "y", "return x+y") console.log( "valueOf", fn.valueOf() === fn );// true object類型 console.log( "toString", fn.toString() === fn );// false string類型 console.log( "valueOf", fn2.valueOf() === fn2 );// true object類型 console.log( "toString", fn2.toString() === fn2 );// false string類型 console.log( fn.valueOf() === fn.toString());// false console.log( fn2.valueOf() === fn2.toString());// false // Date var date = new Date(); console.log( "valueOf", date.valueOf() );// 1501830320383 number類型 console.log( "toString", date.toString() );// Fri Aug 04 2017 15:05:45 GMT+0800 (中國標(biāo)準(zhǔn)時(shí)間) string類型 console.log( date.valueOf() === date.toString());// false
移步:valueOf() / toString()深入分析對(duì)比
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/84658.html
摘要:一寫在前面最近重讀高級(jí)程序設(shè)計(jì),總結(jié)下來,查漏補(bǔ)缺。但這種影響是單向的修改命名參數(shù)不會(huì)改變中對(duì)應(yīng)的值。這是因?yàn)閷?duì)象的長度是由傳入的參數(shù)個(gè)數(shù)決定的,不是由定義函數(shù)時(shí)的命名參數(shù)的個(gè)數(shù)決定的。實(shí)際改變會(huì)同步,改變也會(huì)同步 一、寫在前面 最近重讀《JavaScript高級(jí)程序設(shè)計(jì)》,總結(jié)下來,查漏補(bǔ)缺。 二、JS簡介 2.1 JS組成 ECMAscript:以ECMA-262為基礎(chǔ)的語言,由...
摘要:為了每個(gè)對(duì)象都能通過來檢測,需要以或者的形式來調(diào)用,傳遞要檢查的對(duì)象作為第一個(gè)參數(shù),稱為。對(duì)象都是動(dòng)態(tài)的,這就意味著每次訪問對(duì)象,都會(huì)運(yùn)行一次查詢。是語言中立的用于訪問和操作和文檔。 一、第三章 基本概念: 1.理解參數(shù) 1.1 可以向函數(shù)中傳遞任意數(shù)量的參數(shù),并且可以通過arguments對(duì)象來訪問這些參數(shù)。 1.2 arguments對(duì)象只是類似數(shù)組,它通過length來確定傳進(jìn)來...
摘要:寫在開頭本篇是小紅書筆記的第六篇,也許你會(huì)奇怪第六篇筆記才寫語法基礎(chǔ),筆者是不是穿越了??梢撇焦P者的文章中替換方式參考文檔高級(jí)程序設(shè)計(jì)作者以樂之名本文原創(chuàng),有不當(dāng)?shù)牡胤綒g迎指出。 showImg(https://segmentfault.com/img/bVblGMc?w=600&h=400); 寫在開頭 本篇是小紅書筆記的第六篇,也許你會(huì)奇怪第六篇筆記才寫語法基礎(chǔ),筆者是不是穿越了。...
摘要:默認(rèn)情況下,方法以十進(jìn)制格式返回?cái)?shù)值的字符串表示。注意,默認(rèn)的沒有參數(shù)的輸出值與指定基數(shù)時(shí)的輸出值相同。但是,在上,他們兩個(gè)表現(xiàn)出了截然不同的形式,在對(duì)一個(gè)對(duì)象類型進(jìn)行時(shí),直接返回原對(duì)象,而則返回。 toString()方法 要把一個(gè)值轉(zhuǎn)換為一個(gè)字符串,最常用的就是,使用幾乎每個(gè)值都有的toString()方法,這個(gè)方法唯一要做的就是返回相應(yīng)值的字符串表現(xiàn)。 數(shù)值、布爾值、對(duì)象和字符串...
摘要:要比較相等性之前,不能將和轉(zhuǎn)換成其他任何值。如果有一個(gè)操作數(shù)是,則相等操作符返回,而不相等操作符返回。重要提示即使兩個(gè)操作數(shù)都是,相等操作符也返回因?yàn)榘凑找?guī)則,不等于。 關(guān)系運(yùn)算符 關(guān)系運(yùn)算符有小于()、小于等于(=)四種,它們都返回一個(gè)布爾值 《javascript高級(jí)程序設(shè)計(jì)》書中的規(guī)則是這樣描述運(yùn)算規(guī)則: (1)如果兩個(gè)操作數(shù)都是數(shù)值,則執(zhí)行數(shù)值比較; (2)如果兩個(gè)操作數(shù)都是字...
閱讀 2962·2021-10-18 13:33
閱讀 846·2019-08-30 14:20
閱讀 2633·2019-08-30 13:14
閱讀 2524·2019-08-29 18:38
閱讀 2892·2019-08-29 16:44
閱讀 1216·2019-08-29 15:23
閱讀 3491·2019-08-29 13:28
閱讀 1918·2019-08-28 18:00