在JavaScript中变量类型强行转换
2008-08-25 09:10
525 查看
在JavaScript中变量类型强行转换
在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")。
所以使用变量类型强制转换,就可能避免这类默认转换带来的潜在理解出错的问题。
在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")。
所以使用变量类型强制转换,就可能避免这类默认转换带来的潜在理解出错的问题。
相关文章推荐
- 在JavaScript中也玩变量类型强行转换
- 在JavaScript中也玩变量类型强行转换
- 在JavaScript中也玩变量类型强行转换
- 在JavaScript中也玩变量类型强行转换
- 在JavaScript中也玩变量类型强行转换
- JavaScript查看变量类型与变量类型的转换
- [JS]JavaScript数据类型与变量类型转换
- JavaScript 笔记(2) -- 类型转换 & 正则表达 & 变量提升 & 表单验证
- 【Web前端学习笔记】Javascript_01_变量,数据类型,类型转换
- javascript入门一:变量类型转换
- javascript中变量的类型转换
- JavaScript 变量类型与类型转换
- JavaScript中将字符串类型的变量转换成日期类型
- JavaScript学习(四):JavaScript类型转换以及变量作用域
- javascript的基础学习——Javascript组成、变量类型(类型转换)、isNaN()、作用域和闭包
- (3)JavaScript基础(基本语法:变量与数据类型、类型转换、运算符、流程控制、函数、对象、自定义对象、原型)
- 补点JavaScript 基础:字符串到数字类型的转换(Number, +, ~~, parseInt, parseFloat)
- 显式类型转换/隐式类型转换/变量作用域
- 不同类型变量转换---------ATL提供的所有转换宏
- javascript数据类型转换