Iwen's blog Iwen's blog
首页
  • 前端文章

    • JavaScript
    • Vue
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《JavaScript高级程序设计》笔记
    • 《ES6 教程》笔记
    • 《Vue》笔记
    • 《TypeScript 从零实现 axios》
    • 小程序笔记
  • HTML
  • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • Linux
  • 学习
  • 面试
  • 心情杂货
  • 友情链接
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
复盘
关于

Iwen

不摸鱼的哥哥
首页
  • 前端文章

    • JavaScript
    • Vue
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《JavaScript高级程序设计》笔记
    • 《ES6 教程》笔记
    • 《Vue》笔记
    • 《TypeScript 从零实现 axios》
    • 小程序笔记
  • HTML
  • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • Linux
  • 学习
  • 面试
  • 心情杂货
  • 友情链接
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
复盘
关于
  • Vue

  • Vue进阶

  • CSS

  • ES6

  • Base

  • Core

  • Array

    • 基础方法
    • 数组遍历总结
    • 扁平化
    • 数组去重
    • 判断数组中是否包含某个值
    • 伪数组转换为真数组
      • 什么是伪数组
      • 常见的伪数组
      • slice方法
      • concat.apply
      • Array.form() 扩展运算符
      • for 循环
      • 原型继承
    • 数组中强大的reduce
    • 前端模块化
  • Object

  • String

  • Async

  • Browser

  • Http

  • 性能优化

  • 正则

  • 经典总结

  • 设计模式

  • 数据结构

  • 算法

  • 手写

  • TypeScript

  • 复盘
  • Array
Mr.w
2020-11-29

伪数组转换为真数组

# 伪数组转换为真数组

# 什么是伪数组

伪数组也称类数组。像arguments 或者 获取一组元素返回的集合都是伪数组。 伪数组如何转换成真正数组,其实我们很少去这么做,但是那帮面试官可能会问,并且不止一种方法让你去实现

# 常见的伪数组

  • 参数数组:arguments
  • DOM对象列表HTMLCollection():比如通过document.getElementsByTagName得到的列表
  • jquery对象:比如$("div")
// 伪数组是一个Object,而真实的数组是一个Array
console.log(list instanceof Array);  // false
console.log(list instanceof Object);  // true

// 拥有length属性和数值下标属性
// 伪数组没有真实数组的方法
list.forEach((ele) => console.log(ele))  // list.forEach is not a function
1
2
3
4
5
6
7

下面来看看,怎么转为正常的数组

# slice方法

Array.prototype.slice.call(list) && [].slice.call(list)

使用数组的slice()方法 它返回的是数组,使用call或者apply指向伪数组,其内部实现原理,也就是for循环本身

Array.prototype.slice = function (start, end) {
  start = start || 0
  end = start || this.length
  const arr = []
  for (var i = start; i < end; i++) {
    arr.push(this[i])
  }
  return arr
}
1
2
3
4
5
6
7
8
9

# concat.apply

拼接成新的数组 Array.prototype.concat.apply([], list)

# Array.form() 扩展运算符

ES6果然是简洁、强大的存在

[...list]           // 扩展运算符
Array.from(list)    // from
1
2

# for 循环

当然,最原始的方法就是再创建一个数组,用for循环把类数组的每个属性值放在里面,不管是对象还是数组,仍是无所不能

let arr = [];
for(let i = 0; i < list.length; i++){
    arr.push(list[i])
}
1
2
3
4

# 原型继承

判断数组中是否包含某个值
数组中强大的reduce

← 判断数组中是否包含某个值 数组中强大的reduce→

最近更新
01
flex布局页面自适应滚动条问题
12-28
02
前后端分离开发请求接口跨域如何携带cookie的问题
12-28
03
怎么实现div长宽比固定width-height4比3
12-28
更多文章>
Theme by Vdoing | Copyright © 2017-2022 Iwen | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式