JavaScript之数组基础


slice :

	var arr = [1, 2, 3, 4, 5, 6];
    var newArr = arr.slice(1, 3); // [2,3]
    var newArr2 = arr.slice(1); //[2,3,4,5,6]
    var newArr3 = arr.slice(-3); //[4,5,6]

join:

	var arr = [1, 2, 3];
    var newArr = arr.join('-'); //1-2-3

split:

	var a = '1-2-3';
    var newArr = a.split('-'); //[1, 2, 3]

例1.

	var str = 'alibaba';
    var str1 = 'baidu';
    var str2 = 'tencent';
    var str3 = 'toutiao';
    var str4 = 'wangyi';
    var str5 = 'xiaowang';

    var arr = [str, str1, str2, str3, str4, str5];
    var newArr = arr.join(''); //alibababaidutencenttoutiaowangyixiaowang

类数组:

	function test() {
      console.log(arguments);
      arguments.push(4);
    }
    test(1, 2, 3); //arguments.push is not a function

称为类数组

var obj = {
      '0': 'a',
      '1': 'b',
      '2': 'c',
      'length': '3',
      'push': Array.prototype.push
    }
    // obj.push('d');
    // obj;
    // {
    //   '0': 'a',
    //   '1': 'b',
    //   '2': 'c',
    //   '3':'d',
    //   'length': '3',
    //   'push': Array.prototype.push
    // }
var obj = {
      '2': 'a',
      '3': 'b',
      'length': '4', //length 是几就在第几位上push元素
      'push': Array.prototype.push,
      // 'splice': Array.prototype.splice
    }
    obj.push('c');
    obj.push('d');
    // obj: {
    //   '2': 'c',
    //   '3': 'd',
    //   'length': '4',
    //   'push': Array.prototype.push,
    // }


    //属性要为索引(数字)属性,必须有length属性,最好加上push

    // Array.prototype.push = function (target) {
    //   obj[obj.length] = target;
    //   obj.length++;
    // }

既能当数组又可以当对象用:

//既能当数组又可以当对象用
    var obj = {
      '0': 'a',
      '1': 'b',
      '2': 'c',
      name: 'abc',
      age: 123,
      length: 3,
      push: Array.prototype.push,
      splice: Array.prototype.splice
    }

    for (var prop in obj) {
      console.log(obj[prop]);
    }

封装typeof :

	function type(target) {
      var ret = typeof (target);
      var template = {
        '[object Array]': 'array',
        '[object Object]': 'object',
        '[object Number]': 'number - object',
        '[object Boolean]': 'boolean - object',
        '[object String]': 'string - object',
      }
      if (target == null) {
        return null;
      } else if (ret == 'object') {
        var str = Object.prototype.toString.call(target);
        return template[str];
      } else {
        return ret;
      }
    }

    //1.原始值 引用值
    //2.区分引用值
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值