实际开发当中,我们经常会遇到类似诸如下面的需求:
在本文中,我们将讨论四种可用于搜索数组中项目的方法。这些方法是:
接下来,我们就一起来看一下这四种方式
我们可以使用 Array.filter() 方法在数组中查找满足特定条件的元素。
例如,如果我们要获取大于10的数字数组中的所有项目,则可以执行以下操作:
const array = [10, 11, 3, 20, 5];
const greaterThanTen = array.filter(element => element > 10);
console.log(greaterThanTen) //[11, 20]
使用 array.filter() 方法的语法如下:
let newArray = array.filter(callback);
着这里:
如果数组中没有项目符合条件,则返回一个空数组。
有时,我们不需要满足特定条件的所有元素。我们只需要一个符合条件的元素。在这种情况下,需要使用find()方法。
使用 Array.find()方法查找满足特定条件的第一个元素。就像 filter 方法一样,它以回调为参数,并返回满足回调条件的第一个元素。
我们尝试一下在上面的示例中对数组使用 find 方法。
const array = [10, 11, 3, 20, 5];
const greaterThanTen = array.find(element => element > 10);
console.log(greaterThanTen)//11
array.find() 的语法为
let element = array.find(callback);
callback 是在数组中的每个值上执行的函数,带有三个参数:
但是请注意,如果数组中没有项目符合条件,则返回 undefined。
但是,如果想检查某个元素是否在数组中怎么办?
includes() 方法确定数组是否包含某个值,并在适当时返回 true 或 false。
因此,在上面的示例中,如果我们要检查20是否为数组中的元素之一,则可以执行以下操作:
const array = [10, 11, 3, 20, 5];
const includesTwenty = array.includes(20);
console.log(includesTwenty)//true
你会注意到此方法与其他方法之间的区别。此方法接受值而不是回调作为参数。这是 include 方法的语法:
const includesValue = array.includes(valueToFind, fromIndex)
要了解索引的概念,让我们再次使用上面的示例。
如果要检查数组是否在第一个元素之外的其他位置包含10个,可以执行如下操作:
const array = [10, 11, 3, 20, 5];
const includesTenTwice = array.includes(10, 1);
console.log(includesTenTwice)//false
indexOf() 方法返回可以在数组中找到给定元素的第一个索引。如果数组中不存在该元素,则返回 -1。
回到例子。让我们找到数组中 3 的索引。
const array = [10, 11, 3, 20, 5];
const indexOfThree = array.indexOf(3);
console.log(indexOfThree)//2
其语法类似于该 includes 方法的语法。
const indexOfElement = array.indexOf(element, fromIndex)
请务必注意,includes 和 indexOf 方法都使用严格的相等性('===')搜索数组。如果值的类型不同(例如4和'4'),它们将分别返回 false 和 -1。
使用这些数组方法,无需使用 for 循环即可搜索数组。根据您的需求,您可以决定哪种方法最适合您的用例。
以下是何时使用每种方法的摘要:
我们在日常开发中,常常有判断某值的需求,今天我们总结一下常见的几种用来判断是否为数组的 JavaScript 方法。
Array.isArray() 是ES5新增的方法,用于确定传递的值是否是一个数组,如果是数组,则返回 true,否则返回 false。
let arr = [];
console.log(Array.isArray(arr)); // true
下面的函数调用都返回 true:
Array.isArray([]);
Array.isArray([1]);
Array.isArray(new Array());
Array.isArray(new Array("a", "b", "c", "d"));
需要注意的一点是:其实 Array.prototype 也是一个数组。
Array.isArray(Array.prototype); // true
下面的函数调用都返回 false:
Array.isArray();
Array.isArray({});
Array.isArray(null);
Array.isArray(undefined);
Array.isArray(17);
Array.isArray('Array');
Array.isArray(true);
Array.isArray(false);
Array.isArray(new Uint8Array(32))
Array.isArray({ __proto__: Array.prototype });
兼容性如下图:
可以看到,新版的主流浏览器都是支持该方法的,可以放心使用。
Object 的每个实例都有构造函数 constructor,用于保存着用于创建当前对象的函数
let arr = [];
console.log(arr.constructor === Array); // true
需要注意的是,constructor 有被修改的风险,判断结果不一定准确,比如:
let arr = [1, 2, 3];
arr.constructor = function () { }
console.log(arr.constructor === Array); // false
一般不推荐使用 constructor 来判断是否为数组,我们只需要知道有这么一个方法就行。
instanceof 运算符用于检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上。举个例子:
// 定义构造函数
function C() {}
function D() {}
var o = new C();
o instanceof C; // true,因为 Object.getPrototypeOf(o) === C.prototype
o instanceof D; // false,因为 D.prototype 不在 o 的原型链上
o instanceof Object; // true,因为 Object.prototype.isPrototypeOf(o) 返回 true
C.prototype instanceof Object; // true,同上
用 instanceof 来判断是否为数组的用法如下:
let arr = [];
console.log(arr instanceof Array); // true
使用 instanceof 需要注意两点:
isPrototypeOf() 可以用于测试一个对象是否存在于另一个对象的原型链上。用法如下:
function Foo() {}
function Bar() {}
function Baz() {}
Bar.prototype = Object.create(Foo.prototype);
Baz.prototype = Object.create(Bar.prototype);
var baz = new Baz();
console.log(Baz.prototype.isPrototypeOf(baz)); // true
console.log(Bar.prototype.isPrototypeOf(baz)); // true
console.log(Foo.prototype.isPrototypeOf(baz)); // true
console.log(Object.prototype.isPrototypeOf(baz)); // true
如果要用 isPrototypeOf 来判断传入参数是否为数组,可以这样用:
let arr = [];
console.log(Array.prototype.isPrototypeOf(arr)); // true
每个对象都有一个 toString() 方法,当该对象被表示为一个文本值时,或者一个对象以预期的字符串方式引用时自动调用。
默认情况下,toString() 方法被每个 Object 对象继承。如果此方法在自定义对象中未被覆盖,toString() 返回 "[object type]" 字符串,其中 type 是对象的类型。
可以通过 toString() 来获取每个对象的类型。为了每个对象都能通过 Object.prototype.toString() 来检测,需要以 Function.prototype.call() 或者 Function.prototype.apply() 的形式来调用,传递要检查的对象作为第一个参数,称为 thisArg。用法如下:
var toString = Object.prototype.toString;
toString.call(new Date); // [object Date]
toString.call(new String); // [object String]
toString.call(Math); // [object Math]
//Since JavaScript 1.8.5
toString.call(undefined); // [object Undefined]
toString.call(null); // [object Null]
如果要用来判断一个对象是否为数组,可这样使用:
let arr = [];
console.log(Object.prototype.toString.call(arr) === "[object Array]"); // true
兼容性如下:
说到判断类型,可能很多人都会想到 typeof 方法,我们这里来复习一下 typeof 相关内容。
typeof 操作符返回一个字符串,表示未经计算的操作数的类型。
console.log(typeof 42); // "number"
console.log(typeof 'blubber'); // "string"
console.log(typeof true); // "boolean"
console.log(typeof undeclaredVariable); // "undefined"
typeof 可能的返回值如下:
通过上图可以看到,数组对象属于“其他任何对象”,所以数组对象的 typeof 返回值是 “object”:
let arr = [];
console.log(typeof arr); // "object"
所以,我们要尽量避免使用 typeof。
以上就是几种用来判断一个值是否为数组的几种方法,当然有好用的也有不好用的,但是不管怎样,我们知道有这么回事总归是好的。总结一下:
~
~本文完,感谢阅读!
~
学习有趣的知识,结识有趣的朋友,塑造有趣的灵魂!
大家好,我是〖编程三昧〗的作者 隐逸王,我的公众号是『编程三昧』,欢迎关注,希望大家多多指教!
你来,怀揣期望,我有墨香相迎! 你归,无论得失,唯以余韵相赠!
知识与技能并重,内力和外功兼修,理论和实践两手都要抓、两手都要硬!
avaScript 提供了一系列强大的数组方法,这些方法可以极大地简化数组的操作和处理。理解并掌握这些方法对任何JavaScript开发者来说都是至关重要的。
数组方法可以分为几类,包括添加和移除元素的方法、遍历和变换的方法、查找和筛选的方法,以及其他杂项方法。添加和移除元素的方法如 .push() 和 .unshift(),分别用于在数组末尾和开头添加元素,而 .pop() 和 .shift() 则用于移除数组末尾和开头的元素。这些方法修改了原数组的长度,并返回被移除的元素。
遍历和变换的方法如 .map() 和 .filter() 允许开发者对数组中的每个元素进行操作,并返回一个新的数组。.map() 方法对数组中的每个元素执行给定的函数,并返回包含结果的新数组,而 .filter() 则返回一个新的数组,包含所有通过指定函数测试的元素。
查找和筛选的方法如 .includes() 和 .find() 提供了在数组中查找特定元素的能力。.includes() 检查数组是否包含某个元素,并返回一个布尔值。.find() 返回数组中满足提供的测试函数的第一个元素的值,或者在没有满足测试函数的元素时返回 undefined。
其他重要的数组方法还包括 .reverse()、.slice() 和 .splice()。.reverse() 颠倒数组中元素的顺序。.slice() 返回一个新的数组对象,这一对象是原数组的一个浅拷贝,由开始索引到结束索引(不包括结束索引)选择的部分组成。.splice() 方法则可以添加或移除数组中的元素,并返回被移除的元素。
js中数组方法
总的来说,这些方法不仅可以极大地提高代码的可读性和维护性,还能使数组操作更加高效和简洁。无论是进行简单的元素添加和移除,还是复杂的数据转换和筛选,JavaScript 的数组方法都能提供强有力的支持。掌握这些方法将有助于开发者在编写代码时更加得心应手,处理数组相关的任务也会变得更加轻松。
*请认真填写需求信息,我们会在24小时内与您取得联系。