这篇文章主要介绍了 JS 判断元素是否在数组内的实现代码, 需要的朋友可以参考下
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
一、JQuery
如果是用 JQuery 的话,可以用 inArray() 函数:
jquery inarray() 函数详解
jquery.inarray(value,array)
确定第一个参数在数组中的位置 (如果没有找到则返回 -1)。
determine the index of the first parameter in the array (-1 if not found).
返回值
jquery
参数
value (any) : 用于在数组中查找是否存在
array (array) : 待处理数组。
用法为:
- $.inArray(value, array)
二、自己写函数
- function contains(arr, obj) {
- var i = arr.length;
- while (i--) {
- if (arr[i] === obj) {
- return true;
- }
- }
- return false;
- }
用法为:
- var arr = new Array(1, 2, 3);
- contains(arr, 2);//返回true
- contains(arr, 4);//返回false
三、给 Array 增加一个函数
- Array.prototype.contains = function (obj) {
- var i = this.length;
- while (i--) {
- if (this[i] === obj) {
- return true;
- }
- }
- return false;
- }
使用方法:
- [1, 2, 3].contains(2); //返回true
- [1, 2, 3].contains('2'); //返回false
四、使用 indexOf
但是有个问题是 IndexOf 在某些 IE 版本中是不兼容的,可以用下面的方法:
- if (!Array.indexOf) {
- Array.prototype.indexOf = function (obj) {
- for (var i = 0; i < this.length; i++) {
- if (this[i] == obj) {
- return i;
- }
- }
- return -1;
- }
- }
先判断 Array 是否有 indexOf 方法,如果没有就扩展出此方法。
所以上面代码要写在使用 indexOf 方法的代码之前:
- var arr = new Array('1', '2', '3');
- if (!Array.indexOf) {
- Array.prototype.indexOf = function(obj) {
- for (var i = 0; i < this.length; i++) {
- if (this[i] == obj) {
- return i;
- }
- }
- return - 1;
- }
- }
- var index = arr.indexOf('1'); //为index赋值为0
来源: http://www.phperz.com/article/17/0222/266479.html