摘要:一数组入栈二数组出栈三数组入队四数组出队纯手写,如有不善,请指正
一、myPush()
//myPush() 数组入栈 Array.prototype.myPush = function(){ var L = this.length; for(var i = L ; i < L + arguments.length ; i++){ this[i] = arguments[i - L]; } return this.length; }二、myPop()
//Mypop() 数组出栈 Array.prototype.myPop = function(){ if (this.length == 0) { return undefined; } var last = this[this.length-1]; this.length = this.length-1; return last; }三、myUnshitf()
//myUnshift 数组入队 Array.prototype.myUnshift = function(){ var L = this.length; for(var i = L + arguments.length - 1 ; i >= 0 ; i--){ if(i > arguments.length - 1){ this[i] = this[i - arguments.length]; }else{ this[i] = arguments[i]; } } return this.length; }四、myShitf()
//myShift()数组出队 Array.prototype.myShift = function(){ if (this.length == 0) { return undefined; } var firstElement = this[0]; for(var i = 1 ; i < this.length ; i++){ this[i-1] = this[i]; } this.length = this.length-1; return firstElement; }
纯手写,如有不善,请指正 ^_^
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/52306.html
摘要:一数组入栈二数组出栈三数组入队四数组出队纯手写,如有不善,请指正 一、myPush() //myPush() 数组入栈 Array.prototype.myPush = function(){ var L = this.length; for(var i = L ; i < L + arguments.length ; i++){ this[i] = a...
一、mySlice() //mySplice 选取数组的的一部分,并返回一个新数组 Array.prototype.mySlice = function(start,end){ var arr = []; if(arguments.length == 0){ //如果不传参数,返回一个原数组副本 start = 0; end...
摘要:有副作用尾递归,即在函数末尾自调用自己想的使用累加器实现函数式重写下面这种写法,很不优雅最好可以实现组合任意个函数,效果如下实现思路在我在 解决大数相加的方法有很多,网上很容易搜到,下面介绍两种,一种是在网上抄的,一种是自己想的,我将他们都用函数式的方式重写了一遍。 这种是在网上抄的,的确非常简洁 function add(a,b) { let res=, c=0; a = a...
摘要:一数组每个元素都执行一次回调函数二检测数值元素的每个元素是否都符合条件三检测数组元素中是否有元素符合指定条件四检测数值元素,并返回符合条件所有元素的数组五将数组元素计算为一个值从左到右以上回调函数只是手写简化版,无法传参数,若有误或建议,请 一、myForEach //myForeach 数组每个元素都执行一次回调函数 Array.prototype.myForEach = fu...
阅读 1359·2021-10-14 09:43
阅读 4111·2021-09-27 13:57
阅读 4508·2021-09-22 15:54
阅读 2521·2021-09-22 10:54
阅读 2255·2021-09-22 10:02
阅读 2064·2021-08-27 13:11
阅读 832·2019-08-29 18:44
阅读 1616·2019-08-29 15:20