Array对象的方法实现(2)----Array.prototype.every和Array.prototype.fill(实现常规参数的功能)

仅供学习参考,发现错请纠正,谢谢!

4,Array的every方法

//every 检测数组中的值是否存在满足条件的值,全部满足条件返回true和有一个不满足就返回false,不对空数组进行检测,不改变原数组


//语法:array.every(function(currentValue,index,arr), thisValue);


//注意:1,返回一个布尔值。2,原数组不变。

Array.prototype._every = function(fn){
	//获取链接数组的参数param,同时用JSON可以深度拷贝数组Array
	let new_arr = JSON.parse(JSON.stringify(this)),count = 0;
	
	for(let i = 0;i < this.length; i++){
		if(fn(this[i])){
			count++; 
		}else{
			return false;
		}
		if(count === this.length){
			return true;
		}
	}
	return true;
}
			
var everyArr = [2,3,4,1];
var bool0 = everyArr.every(function(index){
	return index > 1;
});
var bool1 = everyArr._every(function(index){
	return index > 1;
});
console.log(bool0);
console.log(bool1);
输出:

false
false
注意:

(1,在谷歌浏览器测试的时候,this === null,直接返回true,所以我在全局直接返回了一个true,但是我感觉判断有问题


5,Array的fill方法

//fill 用于将一个固定值替换数组的元素。


//语法:array.fill(value, start, end);


//注意:1,返回一个数组。2,改变原来的数组。

Array.prototype._fill = function(value, start, end){
	//获取链接数组的参数param,同时用JSON可以深度拷贝数组Array
	let param = arguments, new_arr = JSON.parse(JSON.stringify(this)),that = this;
	
	function loop(num0,num1){
		let param0 = num0 || 0,param1 = num1 || new_arr.length;
		for(let i = param0; i < param1 ; i++){
			that[i] = param[0];
		}
	}
	
	if(param.length === 1){
		loop();
	}else if(param.length === 2){
		loop(param[1]);
	}else if(param.length === 3){
		loop(param[1],param[2]);
	}
	return that;
}

var fillArr = [1,2,3,4,5,6];
var fillArr0 = [1,2,3,4,5,6];
console.log(fillArr.fill(3,0));
console.log(fillArr);
console.log(fillArr0._fill(3,0));
console.log(fillArr0);
注意:

(1,由于在loop函数中用了外部的this,所以需要在外部留住this

Array.prototype.fill = function(value) {
 
    // Steps 1-2.
    var O = Object(this);
 
    // Steps 3-5.
    var len = parseInt(O.length);
 
    // Steps 6-7.
    var relativeStart = parseInt(arguments[1] || 0);
 
    // Step 8.
    var k = relativeStart < 0
            ? Math.max(len + relativeStart, 0)
            : Math.min(relativeStart, len);
 
    // Steps 9-10.
    var relativeEnd = parseInt(arguments[2] || len);
 
    // Step 11.
    var final = relativeEnd < 0
                ? Math.max(len + relativeEnd, 0)
                : Math.min(relativeEnd, len);
 
    // Step 12.
    for (; k < final; k++) {
        O[k] = value;
    }
 
    // Step 13.
    return O;
  };

相关链接:

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/fill



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Rattenking

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值