Javascript 强制类型转换函数


Posted in Javascript onMay 17, 2009

1. Boolean(value):把值转换成Boolean类型;
2. Nnumber(value):把值转换成数字(整型或浮点数);
3. String(value):把值转换成字符串。
我们先来看Boolean():在要转换的值为“至少有一字符的字符串”、“非0的数字”或“对象”,那么Boolean()将返回true,如果要转换的值为“空字符串”、“数字0”、“undefined”,“null”这些话,那么Boolean()会返回false。你可以用以下代码来测试

var t1 = Boolean("");//返回false,空字符串 
var t2 = Boolean("s");//返回true,非空字符串 
var t3 = Boolean(0);//返回false,数字0 
var t3 = Boolean(1),t4 = Boolean(-1);//返回true,非0数字 
var t5 = Boolean(null),t6 = Boolean(undefined);//返回false 
var t7 = Boolean(new Object());//返回true,对象

再来看看Number():Number()与parseInt()和parseFloat()类似,它们区别在于Number()转换是整个值,而parseInt()和parseFloat()则可以只转换开头的数字部分,例如:Number("1.2.3"),Number("123abc")会返回NaN,而parseInt("1.2.3")返回1、parseInt("123abc")返回123、parseFloat("1.2.3")返回1.2、parseFloat("123abc")返回123。Number()会先判断要转换的值能否被完整的转换,然后再判断是调用parseInt()或parseFloat()。下面列了一些值调用Number()之后的结果:
Number(false) 0
Number(true) 1
Number(undefined) NaN
Number(null) 0
Number("1.2") 1.2
Number("12") 12
Number("1.2.3") NaN
Number(new Object()) NaN
Number(123) 123
最后是String():这个以比较简单了,它可以把所有类型的数据转换成字符串,如:String(false)---"false"、String(1)---"1"。它和toString()方法有些不同,区别在于:
var t1 = null; 
var t2 = String(t1);//t2的值 "null" 
var t3 = t1.toString();//这里会报错 
var t4; 
var t5 = String(t4);//t5的值 "undefined" 
var t6 = t4.toString();//这里会报错
Javascript 相关文章推荐
jquery插件validate验证的小例子
May 08 Javascript
jquery中的过滤操作详细解析
Dec 02 Javascript
js构造函数、索引数组和属性的实现方式和使用
Nov 16 Javascript
基于jquery实现导航菜单高亮显示(两种方法)
Aug 23 Javascript
浅谈javascript中的加减时间
Jul 12 Javascript
值得分享的JavaScript实现图片轮播组件
Nov 21 Javascript
如何获取元素的最终background-color
Feb 06 Javascript
详解Angularjs 如何自定义Img的ng-load 事件
Feb 15 Javascript
jQuery条件分页 代替离线查询(附代码)
Aug 17 jQuery
微信小程序使用wxParse解析html的方法示例
Jan 17 Javascript
Vue.js实现的购物车功能详解
Jan 27 Javascript
vue中的inject学习教程
Apr 24 Javascript
jQuery live
May 15 #Javascript
event.keyCode键码值表 附只能输入特定的字符串代码
May 15 #Javascript
javascript Prototype 对象扩展
May 15 #Javascript
JavaScript设置FieldSet展开与收缩
May 15 #Javascript
childNodes.length与children.length的区别
May 14 #Javascript
DOM下的节点属性和操作小结
May 14 #Javascript
JQuery textlimit 显示用户输入的字符数 限制用户输入的字符数
May 14 #Javascript
You might like
PHP 5昨天隆重推出--PHP 5/Zend Engine 2.0新特性
2006/10/09 PHP
Linux下 php5 MySQL5 Apache2 phpMyAdmin ZendOptimizer安装与配置[图文]
2008/11/18 PHP
PHP加密扩展库Mcrypt安装和实例
2013/11/10 PHP
php使用curl抓取qq空间的访客信息示例
2014/02/28 PHP
PHP新特性详解之命名空间、性状与生成器
2017/07/18 PHP
java script编程起步(第三课)
2007/01/10 Javascript
jQuery使用技巧简单汇总
2013/04/18 Javascript
jquery 简单应用示例总结
2013/08/09 Javascript
jQuery Validate 验证,校验规则写在控件中的具体实例
2014/02/27 Javascript
jQuery.Highcharts.js绘制柱状图饼状图曲线图
2015/03/14 Javascript
js前端实现多图图片上传预览的两个方法(推荐)
2016/11/18 Javascript
用headjs来管理和加载js 提高网站加载速度
2016/11/29 Javascript
layui表格实现代码
2017/05/20 Javascript
使用JS动态显示文本
2017/09/09 Javascript
JS计算距当前时间的时间差实例
2017/12/29 Javascript
详解js模板引擎art template数组渲染的方法
2018/10/09 Javascript
七行JSON代码把你的网站变成移动应用过程详解
2019/07/09 Javascript
Python编写屏幕截图程序方法
2015/02/18 Python
Python中生成器和yield语句的用法详解
2015/04/17 Python
详解Python编程中包的概念与管理
2015/10/16 Python
Python实现Sqlite将字段当做索引进行查询的方法
2016/07/21 Python
python开发简易版在线音乐播放器
2017/03/03 Python
Python实现可自定义大小的截屏功能
2018/01/20 Python
对python遍历文件夹中的所有jpg文件的实例详解
2018/12/08 Python
Python 操作 MySQL数据库
2020/09/18 Python
详解Python流程控制语句
2020/10/28 Python
css3一款3D字体带阴影效果的实现步骤
2013/03/20 HTML / CSS
中专毕业生自荐信范文
2013/11/28 职场文书
关于毕业的广播稿
2014/01/10 职场文书
汉语言文学毕业生自荐信范文
2014/03/24 职场文书
英语教师求职信
2014/06/16 职场文书
基层领导干部“四风”问题批评与自我批评
2014/09/23 职场文书
学校四风问题对照检查材料思想汇报
2014/09/26 职场文书
2014年度个人总结范文
2015/03/09 职场文书
Golang 实现获取当前函数名称和文件行号等操作
2021/05/08 Golang
【D4DJ】美少女DJ企划 动画将于明年冬季开播第2季
2022/04/11 日漫