js中数据类型转换是一个很频繁会用到的一部分,那么在实际案例中会出现各种的数据类型,想要满足某些条件,那还必须要不同类型的数据进行转换,今天就通过一个小例子,来找出相对应的数据类型。
先看一个一个数组,数组里的内容很复杂,包含了所有的数据类型,然后我们通过不同的条件找到相对应的内容:
var arr = [ ‘100px‘, ‘abc‘-6, [], -98765, 34, -2, 0, ‘300‘, , function(){alert(1);}, null, document, [], true, ‘200px‘-30,‘23.45元‘, 5, Number(‘abc‘), function(){ alert(3); }, ‘xyz‘-90 ];
题目是:
1、找到arr里所有的数字:-98765, 34, -2, 0, 5
2、找到可以转成数字的:‘100px‘, -98765, 34, -2, 0, ‘300‘, ‘23.45元‘, 5
3、把转成数字以后,最大值判断出来:300
4、把 NaN 所在的位置找出来:1 14 17 19
接下来通过js中的数据类型转换找出来所有的题目相对应的内容:
1 for(var i= 0;i<arr.length;i++){ 2 ?3 ????????//1 思路:必须是数字,还不包含NaN,空白 4 ????????if(isNaN(arr[i])===false && arr[i]!="NaN" && typeof(arr[i]) =="number" ){ 5 ????????????arrNum1.push(arr[i]); 6 ????????????alert(arr[i]) 7 ????????} 8 ????????//2 思路:要通过parseInt和parseFloat把所有的内容转换,然后通过isNaN判断出所有的数字类型 9 ????????if(isNaN(parseInt(arr[i]))==false && isNaN(parseFloat(arr[i]))==false){10 ????????????if(arr[i]==true){11 ????????????????arrNum2.push(0);12 ????????????}else{13 ????????????????arrNum2.push(arr[i]);14 ????????????}15 ????????????alert(arr[i])16 ????????}17 ????????//4 思路:NaN有一个特性它自己不等于它自己18 ????????if(arr[i] !=arr[i]){19 ????????????alert(i);20 ????????}21 ????}22 ????//3 思路:在第二步的基础之上,那么就需要一个临时变量先给每个值进行比较,比临时变量小的忽略;23 ????// 比它大的,就让临时变量等于它;24 ????// 然后接着给下面的每一个再进行比较,依次比较大的替换,小的忽略,直到找到最大的那个即可25 ????var temp=0;26 ????for(var i=0;i<arrNum2.length;i++){27 ????????if(parseFloat(arrNum2[i])>parseFloat(temp)){28 ????????????temp=arrNum2[i];29 ????????}30 ????}31 ????alert(temp);
今天的小例子可能实际项目中不会同样的经常用到,但是只要是比较大小的都必须同类型的才有可比性,不同类型的自然要进行数据类型转换,所以日后的项目中数据类型转换可能会经常用到,JS中的数据类型无非就这几种:数字、字符串、布尔、函数、对象(obj、[]、{}、null)、未定义,万变不离其宗,只要记得基本的就行,当然这个小例子只是为了简单的巩固数据类型的转换,希望对大家有帮助!
好了,今天就这些,明天加油!
js中的数据类型转换(找相应的值小案例)
原文地址:http://www.cnblogs.com/web001/p/7966191.html