zoukankan      html  css  js  c++  java
  • 自己实现一个数组的slice方法

    Array.prototype.mySlice = function mySlice() {
    	var n = arguments[0], m = arguments[1], newAry = [];
    	n = n === undefined ? 0 : (isNaN(n) ? 0 : (n >= 0 ? (n < this.length ? Math.floor(Number(n)) : this.length) : (n < -this.length ? 0 : (n <= -1 ? this.length + Math.ceil(Number(n)) : 0))));
    	m = m === undefined ? this.length : (isNaN(m) ? 0 : (m >= 0 ? (m < this.length ? Math.floor(Number(m)) : this.length) : (m < -this.length ? 0 : this.length + Math.ceil(Number(m)))));
    	while (n < m) {
    		newAry[newAry.length] = this[n];
    		n++;
    	}
    	return newAry;
    };
    

    以下是测试代码,和原生的数组slice方法,功能一致。

    var ary = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
    function compare(n, m) {
    	console.log(n, m, ary.slice(n, m), 'VS', ary.mySlice(n, m));
    }
    
    
    compare(0, -5);
    compare(0, -1.5);
    compare(-1.5);
    compare(-0.1);
    compare(-0.1, 5);
    compare(0);
    compare(undefined, "undefined");
    compare(undefined, undefined);
    compare("undefined", undefined);
    compare(100, undefined);
    compare(-100, undefined);
    compare(10, undefined);
    compare(-10, undefined);
    compare(-10);
    compare(NaN, NaN);
    compare(NaN, undefined);
    compare(undefined, NaN);
    compare(2, 1);
    compare(-12, 13);
    compare(3, 18);
    compare(0, 0);
    compare(-200);
    compare(1, 1);
    compare(-1, undefined);
    compare(-1, 1000);
    compare(2, undefined);
    compare(123, 123, 123);
    compare(0, 123);
    compare(13, undefined)
        
    
  • 相关阅读:
    react中this.setState的理解
    expo:wraning remotedebugger is in a...cause apps to perform slowly
    expo:java.net.socketExcrption:No route to host
    redux的中间件
    js中this的指向
    微信小程序之模板/组件的使用
    js判断手机端
    微信小程序轮播图
    scrollbar样式设置
    CSS绝对定位元素居中的几种方法
  • 原文地址:https://www.cnblogs.com/changzhenan/p/7214005.html
Copyright © 2011-2022 走看看