every() 方法接收一个函数作为参数,判断数组中每一项都是否满足条件,只有所有项都满足条件,才会返回true。
const arr = [11, 5, 2, 4, 111]
const gig = arr.every(elem => elem > 100)
const little = arr.every(elem => elem < 1000)
console.log(gig);//false
console.log(little);//true
every():
判断数组中每一项都是否满足条件,只有所有项都满足条件,才会返回true;
返回值为一个布尔值;
有两个参数:
第一个参数是:callback回调函数
callback回调函数里面的第一个参数是:
ele代表着正在处理的元素
callback回调函数里面的第二个参数是:
index代表着数组的索引值
callback回调函数里面的第三个参数是:
self代表着数组本身
第二个参数是:thisArg(可选)
代表着this默认指向window
const arr = [
{ name: '张三', age: 21 },
{ name: '李四', age: 22 },
{ name: '王五', age: 23 },
];
let obj = {
naem: 'xyz'
}
const newEvery = arr.every((ele, index, self) => {
return ele.age > 10
}, obj)
console.log(newEvery)
通过源码实现every方法:
const arr = [
{ name: '张三', age: 21 },
{ name: '李四', age: 18 },
{ name: '王五', age: 23 },
];
let obj = {
naem: 'xyz'
}
Array.prototype.myEvery = function(func){
let _this = arguments[1] || window;
let flag = true;
for (let i = 0; i < this.length; i++) {
if(func.apply(_this, [this[i], i, this]) == false){
flag = false;
break;
}
}
return flag
}
const newEvery = arr.myEvery((ele, index, self) => {
return ele.age > 10
}, obj)
console.log(newEvery)