DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> Javascript中使用parseInt函數需要注意的問題
Javascript中使用parseInt函數需要注意的問題
編輯:關於JavaScript     

  前些天信用卡站點要接入一個新功能,不過還真比較坑爹,asp站點,大家都知道信用卡的背面是有一個有效期的,在對接銀行中這個信息一定是要傳給銀行做數據校驗,用戶在語音輸入信用卡有效期後,系統會做一個有效期判斷,為了不必要的麻煩,就是判斷過期時間一定不能在一個月內,由於輸入的年月日在三個文本框中,再加上我嫌轉成時間麻煩,就索性直接拿年,月,日的文本內容直接強轉成int類型來判斷,此為背景。

  說了這麼多,終於說到文章主題了,我們知道有效期有這樣的:2015-09-20,我就毫不猶豫的從月文本框中拿出了"09",然後屁顛屁顛的在chrome下做了如下轉換,很開心,搞定。

 

  下午測試小妹妹反饋過來說,信用卡有效期判斷有問題,比較詫異,在自己機器上怎麼試都沒有問題,然後沒轍,只能親自去小妹妹桌上看看,順便搽點油,開著IE調試器調試了下,果然,靈異事件發生了,現在終於找到問題所在了。

 

  當時測試小妹妹裝的是IE8,然後在IE8下面parseint默認會把我的“09”當成八進制,但是又發現不是合法的八進制,最後就拋出了0這個false,我們也看到在chrome下,“09”會默認當做十進制來看的,所以js引擎會理所當然的轉化成了9這個我滿意的結果,所以嘛,IE真的是不按照人的常理出牌,現在我們該如果解決呢?

 

一:解決方案

<1> 剛才討論中也發現了,parseInt在不同的浏覽器下有不同的默認行為處理,沒轍,又看不到parseint底層是怎麼處理的,只能去找javascript的api文檔這個黑盒去看一看,然後就發現一個讓我很驚喜的radix參數。

  知道了這個radix,問題就可以迎刃而解了,現在我只需指定下radix=10即可,如圖:

 

不過後來發現在IE9下面,parseint在缺失radix的時候底層也是默認采用十進制的,終於微軟為了符合大眾口味做了正確的修改。

 

<2>除了parseint這個函數,其實還有一個Number函數也可以幫你解決這個問題,並且在IE7,8上面都是沒有問題的,由於在js中,如果你去new 一下這個Number的話,那就可以生成Number對象了,這一點和C#有一些區別,所以下面我可以用兩種方式看一下。

 

這個Number的好處在於只會處理十進制數值,而且還有其他特殊的玩法,不像parseint只接受string的參數,number可以接受任何類型,比如:

由於看不到Number底層的源碼,所以針對這些問題,我們也只能道聽途說來記住了,這也是JS與其他托管語言不一樣的地方。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved