在JavaScript中也玩變數型別強行轉換

fightplane發表於2007-08-16
我們在C/C++和C#這類強型別語言中,強行轉換變數型別簡直就是家常便飯。可是JavaScript這個動態型別指令碼語言的變數號稱是沒有型別的,那麼我們怎麼轉換它的變數的型別呢?而且還要強行轉

    JavaScript的變數確實是沒有型別的,就是說你var variable後,可以隨便的給variable賦值,不會有任何問題。可是賦給變數的值本身自己卻是有型別的,比如:String、Object、 Boolean和Number等等。所以JS的變數還是有型別轉換的,當然很多時候JS解析引擎會預設處理很多的type convert。不過有的時候也需要我們強行轉換資料型別,最常見的就是:''+數字+數字,這種情況來生成字串累加。

    象:''+數字+數字,這樣的語法真的是比較的ugly,想我們在C中使用(int)xxx和C++中int(xxx)來做型別轉換多麼的清晰明瞭。其實JavaScript也支援這樣的型別轉換語法的,例如:
    <script language="javascript">
    
var str = '100';
    
var num = Number(100);
    alert(
typeof(num) + ': ' + num);
    
var obj = Object(str);
    alert(
typeof(obj) + ': ' + obj);
    
var bool = Boolean(str);
    alert(
typeof(bool) + ': ' + bool);

    
var num = 100;
    
var str = String(num);
    alert(
typeof(str) + ': ' + str);
    
var bool = Boolean(num);
    alert(
typeof(bool) + ': ' + bool);
    
var obj = Object(num);
    alert(
typeof(obj) + ': ' + obj);

    
var bool = true;
    
var str = String(bool);
    alert(
typeof(str) + ': ' + str);
    
var num = Number(bool);
    alert(
typeof(num) + ': ' + num);
    
var obj = Object(bool);
    alert(
typeof(obj) + ': ' + obj);

    
var obj = {};
    
var str = String(obj);
    alert(
typeof(str) + ': ' + str);
    
var num = Number(obj);
    alert(
typeof(num) + ': ' + num);
    
var bool = Boolean(obj);
    alert(
typeof(bool) + ': ' + bool);
    
</script>
    除了Number(obj)轉換失敗,其它強行轉換表示式都能取得有意義的轉換效果。

    使用強行轉換表示式最大的好處就是可以使程式程式碼變得清晰,為本身就型別混亂的JavaScript程式設計減少混淆的可能。

    至少我覺得類似:var str = String(3) + String(3); 比 var str = '' + 3 + 3; 表意更清晰。
    還有預設轉換比較混亂的地方,比如:"88"-8和"88"+8,前者的預設轉換是把字串轉為數字(結果80),而後者又是把數字轉為字串(結果"888")@_@,真是亂。所以使用變數型別強制轉換,就可能避免這類預設轉換帶來的潛在理解出錯的問題。
 

相關文章