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

本文介绍了Array对象的every和fill方法的自定义实现过程。every方法用于检测数组中的所有元素是否都符合指定条件,而fill方法则用于将数组的所有元素填充为指定的固定值。文章通过具体示例展示了这两个方法的使用方式。

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



posted @ 2017-08-29 14:50 Newman·Li 阅读( ...) 评论( ...) 编辑 收藏
你提供的内容是一个 **JavaScript 数组对象的控制台输出(console.log)**,它展示了一个数组及其原型链上的属性方法。我们来逐步解析这个结构: --- ### 🧠 原始数据结构如下(简化版): ```js [ 0: 1, length: 1, [[Prototype]]: Array(0), ...Array Methods..., [[Prototype]]: Object ] ``` --- ### 🔍 详细解释 #### ✅ 第一部分:`0: 1` ```js 0: 1 ``` - 表示数组的第一个元素(索引为 `0`)的值是 `1`。 - 所以这是一个数组,它的第一个元素是数字 `1`。 ```js [1] // 等价的数组表示 ``` --- #### ✅ 第二部分:`length: 1` ```js length: 1 ``` - 表示该数组只有一个元素,长度为 `1`。 --- #### ✅ 第三部分:`[[Prototype]]: Array(0)` ```js [[Prototype]]: Array(0) ``` - 这是 JavaScript 中对象的内部属性,表示该数组的原型对象- `Array(0)` 表示原型是一个空数组对象,里面没有实际元素。 - 通过原型链继承了所有数组的方法,如 `push`, `map`, `filter` 等。 --- #### ✅ 第四部分:列出的所有函数 ```js at: ƒ at() concat: ƒ concat() constructor: ƒ Array() ... ``` - 这些是数组从其原型(Array.prototype)继承来的标准方法- 比如: - `map()`:用于遍历并映射数组元素。 - `filter()`:用于过滤数组元素。 - `push()`:添加元素到数组末尾。 - 等等。 --- #### ✅ 第五部分:`Symbol(Symbol.iterator): ƒ values()` ```js Symbol(Symbol.iterator): ƒ values() ``` - 表示这个数组是可迭代对象(iterable),可以通过 `for...of` 遍历。 - 使用的是 `.values()` 方法作为默认迭代器。 --- #### ✅ 第六部分:`Symbol(Symbol.unscopables)` ```js Symbol(Symbol.unscopables): { at: true, copyWithin: true, entries: true, fill: true, find: true, ... } ``` - 这个 Symbol 属性用于指定哪些方法不应被 `with` 语句绑定。 - 它是一个保护机制,防止某些数组方法在 `with` 上下文中被错误访问。 --- #### ✅ 最后一个 `[[Prototype]]: Object` ```js [[Prototype]]: Object ``` - 所有数组都是对象,因此它们最终继承自 `Object.prototype`。 - 所以数组也可以访问 `toString()`, `hasOwnProperty()` 等对象方法--- ### ✅ 总结 这个对象是一个简单的数组: ```js const arr = [1]; ``` 当你打印 `arr` 到控制台时,浏览器会显示完整的结构,包括: - 当前数组的内容(如 `[1]`) - 其 `.length` - 继承的方法(来自 `Array.prototype` `Object.prototype`) ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值