js中的数据类型转换(找相应的值小案例)

Posted 麦兜家园

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js中的数据类型转换(找相应的值小案例)相关的知识,希望对你有一定的参考价值。

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中的数据类型转换(找相应的值小案例)的主要内容,如果未能解决你的问题,请参考以下文章

JS中的“==”与强制类型转换

java中把json怎么转换成数组?

JS 数据类型转换以其他

JavaScript笔试题(js高级代码片段)

使用Array.Count并匹配案例F#

JS在if中的强制类型转换