首頁 > web前端 > js教程 > 主體

詳細解讀String.valueOf()方法的使用

亚连
發布: 2018-05-21 11:02:36
原創
3753 人瀏覽過

下面我就為大家帶來一篇淺談String.valueOf()方法的使用。現在就分享給大家,也給大家做個參考。

前面的話

關於型別轉換,物件常見的兩個方法是toString()和valueOf()。實際上,這兩個方法也可以應用在包裝類型上。前面已經介紹過toString()方法,本文將介紹valueOf()方法,該方法傳回原值

【1】undefined和null沒有valueOf()方法

undefined.valueOf();//错误
null.valueOf();//错误
登入後複製

【2】布林型資料true與false傳回原值

true.valueOf();//true
typeof true.valueOf();//'boolean'
false.valueOf();//false
typeof false.valueOf();//'boolean'
Boolean.valueOf();//Boolean() { [native code] }
typeof Boolean.valueOf();//'function'
登入後複製

【3】字串型別原值回傳

'1'.valueOf();//'1'
''.valueOf();//''
'abc'.valueOf();//'abc'
String.valueOf();//String() { [native code] }
typeof String.valueOf();//'function'
登入後複製

【4】數值類型分為整數和浮點數進行處理

Number.valueOf();//Number() { [native code] }
typeof Number.valueOf();//'function'
登入後複製

#1、整數直接跟上.valueOf()形式,會報錯,提示無效標記,所以盡量加括號

0.valueOf();//Uncaught SyntaxError: Invalid or unexpected token
(0).valueOf();//0
+0.valueOf();//Uncaught SyntaxError: Invalid or unexpected token
(+0).valueOf();//0
-0.valueOf();//Uncaught SyntaxError: Invalid or unexpected token
(-0).valueOf();//-0
登入後複製

[注意]-0的valueOf()值是-0,而-0的toString()值是'0'

2、浮點數原值回傳

1.23.valueOf();//1.23
+1.23.valueOf();//1.23
-1.23.valueOf();//-1.23
NaN.valueOf();//NaN
Infinity.valueOf();//Infinity
-Infinity.valueOf();//-Infinity
登入後複製

[注意]和toString()不同的是,valueOf()不可以接收轉換基數

【5】物件Object型別及自訂物件類型傳回原物件

{}.valueOf();//报错,Unexpected token .
({}).valueOf();//Object{}
typeof ({}).valueOf();//'object'
({a:123}).valueOf();//Object{a:123}
Object.valueOf();//Object() { [native code] }
typeof Object.valueOf();//'function'
登入後複製
function Person(){
  this.name = 'test';
}
var person1 = new Person();
person1.valueOf();//Person {name: "test"}
登入後複製

【6】函數Function類型傳回原函數

function test(){
  alert(1);//test
}
test.valueOf();/*function test(){
          alert(1);//test
         }*/
Function.valueOf();//Function() { [native code] }
登入後複製

【7】陣列Array類型傳回原數組

[].valueOf();//[]
[1].valueOf();//[1]
[1,2,3,4].valueOf();//[1,2,3,4]
Array.valueOf();//Array() { [native code] }
登入後複製

【8】和其他物件不同,時間Date型別回傳一個數字值,它是this時間值

Date.now();//1465115123742
(new Date()).valueOf();//1465115123742
typeof (new Date()).valueOf();//'number'
Date.valueOf();//Date() { [native code] }
登入後複製

【9】正規則表達式RegExp類型傳回原始正規物件

/ab/i.valueOf();///ab/i
/mom( and dad( and baby)?)?/gi.valueOf();//mom( and dad( and baby)?)?/gi
RegExp.valueOf();//RegExp() { [native code] }
登入後複製

【10】錯誤Error類型

Error.valueOf();//Error() { [native code] }
RangeError.valueOf();//RangeError() { [native code] }
ReferenceError.valueOf();//ReferenceError() { [native code] }
SyntaxError.valueOf();//SyntaxError() { [native code] }
TypeError.valueOf();//TypeError() { [native code] }
URIError.valueOf();//URIError() { [native code] }
登入後複製

##總結

#1、toString()和valueOf()的主要不同點在於,toString()回傳的是字串,而valueOf()回傳的是原始物件

2、由於undefined和null不是對象,所以它們toString()和valueOf()兩個方法都沒有

3、數值Number類型的toString()方法可以接收轉換基數,傳回不同進位的字串形式的數值;而valueOf()方法無法接受轉換基數

4、時間Date型別的toString()方法傳回的表示時間的字串表示;而valueOf()方法則回傳的是現在到1970年1月1日00:00:00的數值類型的毫秒數

上面是我整理給大家的,希望今後會對大家有幫助。

相關文章:

AJAX與JavaScript的使用詳解

#JavaScript怎麼使用ajax操作表單

#javascript 中.min.js 和.js 檔案的差別?
#

以上是詳細解讀String.valueOf()方法的使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板