欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript類型轉換方法及需要注意的問題小結(挺全面)

 更新時間:2010年11月11日 14:33:38   作者:  
JavaScript類型轉換方法及需要注意的問題,在js中經(jīng)常需要對數(shù)據(jù)類型的轉換操作,需要的朋友可以參考下。
一、類型轉換的方法和應該注意的問題:
1.
轉換為布爾型:
1)用兩次非運算(!):
!!5 ==> true
2)用布爾型的構造函數(shù):
new Boolean(5) == > true
值轉換為布爾類型為false
0
,+0,-0,NaN""(空字符串),undefined,null
除上面的值其他值在轉換以后為true,需要特別提到的是:
"0",new Object(),function(){}
2.
轉換為字符串類型:
1)加上空字符串""
123 +
 "" = "123"
2)用字符串構造函數(shù):
new String(123) = "123".
需要特別注意的轉化:
+0 ==> "0"
-0 ==> "0"
-Infinity ==>"-Infinity"
+Infinity ==>"+Infinity"
NaN ==> "NaN"
undefined ==> "undefined"
null ==> "null"
new Object() ==> "[object Object]"
function(){} ==> "function(){}"
3.
轉換為數(shù)值型:
1 取正(+), 減零 -0), 乘一,(*1),除以一(/1),取負(-,這個得到相反的值)。
+"123" = 123
+true = 1
2)用構造函數(shù)Number();
new Number("123") = 123
幾個需要特別注意的轉化:
""
(空字符串) ==> 0
"010" ==> 10
"0x10"(16
進制) ==> 16
"-010" ==> -10
"-0x10" ==> NaN
undefined ==> NaN
null ==> 0
true ==> 1
false ==> 0
new Object() ==> NaN
new function(){} ==> NaN


二、隱式類型轉換:
(1)
二元加法運算(+):如果兩個操作數(shù)中有一個是String類型,將把兩個操作數(shù)轉換為String類型再相加。
如果兩個操作數(shù)中沒有字符串類型,那么將把兩個操作數(shù)轉換為數(shù)值類型再做運算。
舉例:
"123"+123 = "123123";
123+123 = 246
true + true = 2
true + undefined = NaN
(因為undefined轉換為數(shù)值為NaN,所有結果為NaN)
true + null = 1 (null
轉換為數(shù)字是0)
"123" + null = "123null" (
包含字符串將轉化為字符串相加)
"123" + undefined = "123undefined"
undefined同樣適用)
1 + 2 + "123" = "3123" (1+2
是首先按照數(shù)值型計算的)
(2)
二元減乘除運算(-*/):因為只有數(shù)值類型才有 - * / 運算,所以會先將兩個操作數(shù)轉換為數(shù)值型再做運算。
"123"-123 = 0
(3)
一元取正(+),取負運算符(-):取正或者取負都是針對數(shù)值型的運算,所以會將操作數(shù)轉換為數(shù)值型再做運算。
+"123" = 123
-"123" = -123
+"123e" = NaN
+"123f" = NaN
+"123e-2" = 1.23 
(4)
一元非(!)運算符:非運算符需要將操作數(shù)轉化為布爾類型。
!"123" = false
!!"123" = true
!123 = false
!!123 = true
(5)
邏輯運算符(&&)和(||):
&&或者||的兩側被判斷的時候會被轉為布爾類型進行判斷,
但是我在測試的時候卻發(fā)現(xiàn)一個有趣的事情。
&&
運算符:如果有一個項為false,那么表達式返回false,如果所有的項都不為false,那么表達式返回最右邊一個項的原始值。
舉例:
123 && 23 && 45
返回 45,而不是我們想象中的true.
所以如果有 123 && 23 == true 那么應該是false。
至于if(123 && 23) 認為是true那應該是把23轉換為布爾類型了。
||
運算符:
|| 測試的結果也和我想象的不一樣,|| 返回第一個轉換以后不為false的值,如果都為false,它將返回最后一個為false的值(未進行類型轉化之前的值)。
舉例: 
123 || 23
返回 123,而不是想象中的true.
false || null
返回null, 而不是想象中的false
三、類型轉換函數(shù)
1.
parseFloat轉換為浮點數(shù):
字符解析函數(shù)獲取每一個字符直到遇到不屬于數(shù)值的字符,然后返回它已獲取的數(shù)值.
幾個需要特別注意的:
""
(空字符串) ==> NaN
"123e-2" == > 1.23 (
科學計算法是可以識別的)
"010" ==> 10 (8
進制不能識別)
"0x10"==> 0 (16
進制不識別)
"-010" ==> -10 
null,undefined,true,false,new Object(),function(){} ==> NaN
2.parseInt
轉換為有符號整數(shù):
parseFloat相似,但是他會把小數(shù)位舍掉(注意不是四舍五入,是完全舍棄,跟Math.floor處理方式一樣),而且他可以識別八進制和16進制表示方式:
123e-2 == > 1
"123e-2" ==> 123
"010" == > 8 
"0x10" ==> 16
"-010" == > -8 
"-0x10" ==> -16
null,undefined,true,false,new Object(),function(){},-Infinity +Infinity NaN ==> NaN
3.
三個取整函數(shù)的區(qū)別
1Math.ceil():“天花板,很形象吧?就是取大于等于參數(shù)的最小整數(shù)。
8.7 == > 9
-8.7==> -8
2Math.floor():"地板",取小于等于參數(shù)的最小整數(shù)。
8.7 ==> 8
-8.7 ==> -9
3Math.round():"四舍五入"取整數(shù)。

相關文章

  • js仿iphone秒表功能 計算平均數(shù)

    js仿iphone秒表功能 計算平均數(shù)

    這篇文章主要為大家詳細介紹了js仿iphone秒表功能,可以計算平均數(shù),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 自適應高度框架 ----屬個人收藏內(nèi)容

    自適應高度框架 ----屬個人收藏內(nèi)容

    自適應高度框架 ----屬個人收藏內(nèi)容...
    2007-01-01
  • 一文詳解HTML中script 標簽的屬性

    一文詳解HTML中script 標簽的屬性

    在HTML中,<script>標簽用于嵌入或引用JavaScript代碼,在HTML中,<script>標簽用于嵌入或引用JavaScript代碼,本文將詳細的而介紹這兩個標簽,感興趣的同學可以參考一下
    2023-04-04
  • 深入探討TypeScript中類與接口的使用

    深入探討TypeScript中類與接口的使用

    TypeScript是一種強大的編程語言,它在JavaScript的基礎上添加了靜態(tài)類型檢查,使得代碼更加可維護和類型安全,在TypeScript中,類和接口是構建復雜應用程序的關鍵組成部分,本文將深入探討TypeScript中類與接口的使用,需要的朋友可以參考下
    2023-09-09
  • Javascript常用小技巧匯總

    Javascript常用小技巧匯總

    這篇文章主要介紹了Javascript常用小技巧,實例匯總了javascript運算符、表達式及遍歷等常用技巧,需要的朋友可以參考下
    2015-06-06
  • javascript表格的渲染組件

    javascript表格的渲染組件

    這篇文章主要介紹了javascript表格的渲染組件的相關資料,需要的朋友可以參考下
    2015-07-07
  • 微信小程序實現(xiàn)五星評價功能

    微信小程序實現(xiàn)五星評價功能

    這篇文章主要為大家詳細介紹了微信小程序實現(xiàn)五星評價功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • javascript History對象原理解析

    javascript History對象原理解析

    這篇文章主要介紹了javascript History對象原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-02-02
  • js實現(xiàn)鼠標滑動到某個div禁止?jié)L動

    js實現(xiàn)鼠標滑動到某個div禁止?jié)L動

    這篇文章主要為大家詳細介紹了js實現(xiàn)鼠標滑動到某個div禁止?jié)L動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • javascript異步處理工作機制詳解

    javascript異步處理工作機制詳解

    籠統(tǒng)地說,異步在javascript就是延時執(zhí)行。嚴格來說,javascript中的異步編程能力都是由BOM與DOM提供的,如setTimeout,XMLHttpRequest,還有DOM的事件機制,等等很多。這些東西都有一個共同的特點,就是擁有一個回調(diào)函數(shù),實現(xiàn)控制反轉。
    2015-04-04

最新評論