js 数据类型转换总结笔记


Posted in Javascript onJanuary 17, 2011

javascript有如下数据类型的转换方法:
一,转换成数字 xxx*1.0
转换成字符串 xxx+""
二,从一个值中提取另一种类型的值,并完成转换工作。
.提取字符串中的整数:parseInt();
例:parseInt("123zhang")的结果为123
.提取字符串中的浮点数:parseFloat();
例:parseFloat("0.55zhang")的结果为0.55
.执行用字符串表示的一段javascript代码:eval();
例:zhang=eval("1+1")的结果zhang=2
. 转换成字符串: toString() ;
例:zhang=eval("1+1")的结果zhang=2
三,是将整个值从一种类型转换为另一种数据类型(称作基本数据类型转换),
基本数据类型转换的三种方法:
.转换为字符型:String() ; 例:String(678)的结果为"678"
.转换为数值型:Number() ; 例:Number("678")的结果为678
.转换为布尔型:Boolean() ; 例:Boolean("aaa")的结果为true

使用这些方法时,如有必要,尽量对参数和 方法的执行进行判断和异常处理操作。
有在参考文档中看到,如下关于执行效率的总结:
在IE 下,第一种速度最快,第二种次之,第三种最差,但差距不过10万次,差几十百来毫秒而已。
在FF下,第一种和第二种基本上相当,第三种最慢。
速度差别基本上可以忽略。因为差距很小。
但是,从代码的简洁性, 第一种明显写法简便,而且也易读,
而且不会出现第二种的 因为 某个对象没有 toString 方法而报错的问题。况且他始终也是最快的。
所以,个人习惯使用第一种方式来完成数据类型的转换
但是,比如需要“123456abcd”来提取其中的数字,那自然当用parsetInt,和parseFloat之类的函数。
但是要注意,有时候 转换的结果是 NaN 等,需要判断一下。

例异常处理如 :

//执行文本框内的语句,用eval 返回语句执行后的值 
function doFunction(str) { var result = str.replace(new RegExp("\"", "gm"), ""); 
//判断语句是否合法 
var reg = /\s*[A-Za-z]+\s*\('.+'\)\s*$/; 
if (result.match(reg)) // 或者用 reg.test(result); 方法判断 
try { 
result = eval(result); 
return result; 
} 
catch (Error) { 
alert("抱歉!语句无法执行转化。注意语法和拼写。"); 
return; 
} 
else alert("请检查数据类型转换语句的格式及语法!"); 
}

有关数据转换方法的其他测试示例如下:
例  句 结  果
parseInt('1234') 1234
parseInt('1234.00') 1234
parseInt('1234abc') 1234
parseInt('abc1234') undefined(转换失败)
parseFloat('1234.123') 1234.123
parseFloat('1234.123a') 1234.123
parseFloat('a1234.123') NaN
Number('1234.123') 1234.123
Number('1234.123aa') NaN
String(eval('12+10')) 22
Boolean('0'),Boolean('567'),Boolean(567) true
Boolean(null),Boolean(false),Boolean(0),Boolean(''),Boolean() false
this.toString() [object]
(typeof(this)).toString() object
eval('12+34') 46
eval('12+34')+'' 46
eval('12+34')*1.0 46
typeof(eval('12+34')*1.0) number
typeof(eval('12+34')+'') string

注:测试时的环境是 vs2008,ie8...,是在页面上输入的语句,js里用eval处理上表中左栏的转换例句。

使用时或许需要修改符号等。

Javascript 相关文章推荐
在IE模态窗口中自由查看HTML源码的方法
Mar 08 Javascript
YUI 读码日记之 YAHOO.util.Dom - Part.1
Mar 22 Javascript
js对象数组按属性快速排序
Jan 31 Javascript
jquery ajax例子返回值详解
Sep 11 Javascript
如何将网页表格内容导入excel
Feb 18 Javascript
JavaScript获取function所有参数名的方法
Oct 30 Javascript
jQuery获取DOM节点实例分析(2种方式)
Dec 15 Javascript
快速学习AngularJs HTTP响应拦截器
Dec 31 Javascript
AngularJS通过$sce输出html的方法
Sep 22 Javascript
jQuery实现的购物车物品数量加减功能代码
Nov 16 Javascript
vue中的mvvm模式讲解
Jan 31 Javascript
java实现单链表增删改查的实例代码详解
Aug 30 Javascript
简短几句 通俗解释javascript的闭包
Jan 17 #Javascript
javascript 内存回收机制理解
Jan 17 #Javascript
javascript 延迟加载技术(lazyload)简单实现
Jan 17 #Javascript
关于COOKIE个数与大小的问题
Jan 17 #Javascript
js实现的跟随鼠标移动的时钟效果(中英文日期显示)
Jan 17 #Javascript
Jquery 插件开发笔记整理
Jan 17 #Javascript
JQuery学习笔记 nt-child的使用
Jan 17 #Javascript
You might like
让你的网站首页自动选择语言转跳
2006/12/06 PHP
php PDO中文乱码解决办法
2009/07/20 PHP
php记录日志的实现代码
2011/08/08 PHP
ThinkPHP3.0略缩图不能保存到子目录的解决方法
2012/09/30 PHP
php删除与复制文件夹及其文件夹下所有文件的实现代码
2013/01/23 PHP
php删除数组中重复元素的方法
2015/12/22 PHP
浅谈php中urlencode与rawurlencode的区别
2016/09/05 PHP
PHP count()函数讲解
2019/02/03 PHP
JavaScript操作XML实例代码(获取新闻标题并分页,并分页)
2010/05/25 Javascript
JavaScript高级程序设计 读书笔记之十 本地对象Date日期
2012/02/27 Javascript
用javascript关闭本窗口技巧小结
2014/09/05 Javascript
浅谈jQuery事件绑定原理
2015/01/02 Javascript
JavaScript中的getMilliseconds()方法使用详解
2015/06/10 Javascript
JS+CSS实现闪烁字体效果代码
2016/04/05 Javascript
JavaScript实现简易的天数计算器实例【附demo源码下载】
2017/01/18 Javascript
js中的触发事件对象event.srcElement与event.target详解
2017/03/15 Javascript
JavaScript箭头(arrow)函数详解
2017/06/04 Javascript
详解Angular-cli生成组件修改css成less或sass的实例
2017/07/27 Javascript
vue elementUI table表格数据 滚动懒加载的实现方法
2019/04/04 Javascript
vue项目中使用scss的方法步骤
2019/05/16 Javascript
vue组件三大核心概念图文详解
2019/05/30 Javascript
只有 20 行的 JavaScript 模板引擎实例详解
2020/05/11 Javascript
零基础写python爬虫之爬虫的定义及URL构成
2014/11/04 Python
Python编程之列表操作实例详解【创建、使用、更新、删除】
2017/07/22 Python
python的内存管理和垃圾回收机制详解
2019/05/18 Python
解决使用export_graphviz可视化树报错的问题
2019/08/09 Python
Python如何将函数值赋给变量
2020/04/28 Python
keras导入weights方式
2020/06/12 Python
澳大利亚在线奢侈品时尚零售平台:Azura Runway
2021/01/13 全球购物
什么是动态端口(Dynamic Ports)?动态端口的范围是多少?
2014/12/12 面试题
经济管理专业毕业生推荐信
2013/11/11 职场文书
荷叶圆圆教学反思
2014/02/01 职场文书
优秀应届生求职信
2014/06/16 职场文书
防灾减灾日活动总结
2014/08/26 职场文书
什么是执行力?9个故事告诉您:成功绝非偶然!
2019/07/05 职场文书
Nginx配置SSL证书出错解决方案
2021/03/31 Servers