html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

JavaScript实现的in_array函数_javascript技巧_

[ ] 已经帮助:人解决问题

在JS中要判断一个值是否在数组中并没有函数直接使用,如PHP中就有in_array()这个函数。但我们可以写一个类似in_array()函数来判断是一个值否在函数中。EQVHTML5中文学习网 - HTML5先行者学习网

EQVHTML5中文学习网 - HTML5先行者学习网

/** * JS判断一个值是否存在数组中 */ // 定义一个判断函数var in_array = function(arr){  // 判断参数是不是数组  var isArr = arr && console.log(      typeof arr==='object' ? arr.constructor===Array ? arr.length ? arr.length===1 ? arr[0]:arr.join(','):'an empty array': arr.constructor: typeof arr     );   // 不是数组则抛出异常  if(!isArr){    throw "arguments is not Array";   }   // 遍历是否在数组中  for(var i=0,k=arr.length;i<k;i++){    if(this==arr[i]){      return true;      }  }   // 如果不在数组中就会返回false  return false;} // 给字符串添加原型String.prototype.in_array = in_array;// 给数字类型添加原型Number.prototype.in_array = in_array; // 声明一个数组var arr = Array('blue','red','110','120'); // 字符串测试var str = 'red';var isInArray = str.in_array(arr);alert(isInArray); // true // 数字测试var num = 119;var isInArray = num.in_array(arr);alert(isInArray); // false

EQVHTML5中文学习网 - HTML5先行者学习网

如果传入的不是数组则会抛出异常EQVHTML5中文学习网 - HTML5先行者学习网

 EQVHTML5中文学习网 - HTML5先行者学习网

/** * JS判断一个值是否存在数组中 */ // 定义一个判断函数var in_array = function(arr){  // 判断参数是不是数组  var isArr = arr && console.log(      typeof arr==='object' ? arr.constructor===Array ? arr.length ? arr.length===1 ? arr[0]:arr.join(','):'an empty array': arr.constructor: typeof arr     );   // 不是数组则抛出异常  if(!isArr){    throw "arguments is not Array";   }   // 遍历是否在数组中  for(var i=0,k=arr.length;i<k;i++){    if(this==arr[i]){      return true;      }  }   // 如果不在数组中就会返回false  return false;} // 给字符串添加原型String.prototype.in_array = in_array;// 给数字类型添加原型Number.prototype.in_array = in_array; // 声明一个数组var arr = null; // 字符串测试var str = 'red';var isInArray = str.in_array(arr);alert(isInArray); // uncaught exception: arguments is not Array

直接报错:EQVHTML5中文学习网 - HTML5先行者学习网
EQVHTML5中文学习网 - HTML5先行者学习网

EQVHTML5中文学习网 - HTML5先行者学习网

EQVHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助