js数据类型转换的解决办法

内容摘要
这篇文章主要为大家详细介绍了js数据类型转换的简单示例,具有一定的参考价值,可以用来参考一下。

js中数据类型转换是一个很频繁会用到的一部分,那么在实际案例中会出现各种的
文章正文

这篇文章主要为大家详细介绍了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, 52、找到可以转成数字的:'100px', -98765, 34, -2, 0, '300', '23.45元', 53、把转成数字以后,最大值判断出来:3004、把 NaN 所在的位置找出来:1 14 17 19接下来通过js中的数据类型转换找出来所有的题目相对应的内容: JS代码如下:

/**
 * js数据类型转换
 *
 * @param 
 * @arrange (www.idcnote.com)
 **/
for(var i= 0;i<arr.length;i++){
 //1 思路:必须是数字,还不包含NaN,空白
 if(isNaN(arr[i])===false && arr[i]!="NaN" && typeof(arr[i]) =="number" ){
  arrNum1.push(arr[i]);
  alert(arr[i])
 }
 //2 思路:要通过parseInt和parseFloat把所有的内容转换,然后通过isNaN判断出所有的数字类型
 if(isNaN(parseInt(arr[i]))==false && isNaN(parseFloat(arr[i]))==false){
  if(arr[i]==true){
   arrNum2.push(0);
  }else{
   arrNum2.push(arr[i]);
  }
  alert(arr[i])
 }
 //4 思路:NaN有一个特性它自己不等于它自己
 if(arr[i] !=arr[i]){
  alert(i);
 }
}
//3 思路:在第二步的基础之上,那么就需要一个临时变量先给每个值进行比较,比临时变量小的忽略;
// 比它大的,就让临时变量等于它;
// 然后接着给下面的每一个再进行比较,依次比较大的替换,小的忽略,直到找到最大的那个即可
var temp=0;
for(var i=0;i<arrNum2.length;i++){
 if(parseFloat(arrNum2[i])>parseFloat(temp)){
  temp=arrNum2[i];
 }
}
alert(temp);

// 来自:php教程(www.idcnote.com)
今天的小例子可能实际项目中不会同样的经常用到,但是只要是比较大小的都必须同类型的才有可比性,不同类型的自然要进行数据类型转换,所以日后的项目中数据类型转换可能会经常用到,JS中的数据类型无非就这几种:数字、字符串、布尔、函数、对象(obj、[]、{}、null)、未定义,万变不离其宗,只要记得基本的就行,当然这个小例子只是为了简单的巩固数据类型的转换,希望对大家有帮助!

注:关于js数据类型转换的简单示例的内容就先介绍到这里,更多相关文章的可以留意

代码注释

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!