Array.from()

Array.from()

 

功能:

  1. 将类数组对象转换为数组
  2. 将字符串转换为数组
  3. 拷贝一个素组

Array.from()方法就是将一个类数组对象或者可遍历对象转换成一个真正的数组。
所谓类数组对象,最基本的要求就是具有length属性的对象。

第一个接收参数可以是:类数组对象/字符串/数组/{length:长度}

复制代码
复制代码
类数组对象,属性为数字 且具有length属性
        let arrayLike = {
            0: 'tom',
            1: '65',
            2: '男',
            3: ['jane', 'john', 'Mary'],
            'length': 4
        }
        let arr = Array.from(arrayLike)
        console.log(arr);  // ['tom','65','男',['jane','john','Mary']]
复制代码
复制代码

如果把类数组的length 属性去掉 没有了length的类数组对象. 用Array.form() 就会得到一个空数组

复制代码
复制代码
        let arrayLike = {
            0: 'tom',
            1: '65',
            2: '男',
            3: ['jane', 'john', 'Mary'],
            'length': 4
        }
      delete arrayLike.length
      let   arr = Array.from(arrayLike)
      console.log(arr); //  []
        
复制代码
复制代码

如果将类数组的属性名改为非数字类型

复制代码
复制代码
        let arrayLike = {
            name: 'tom',
            age: '65',
            sex: '男',
            names: ['jane', 'john', 'Mary'],
            'length': 4
        }

        let arr = Array.from(arrayLike)
        console.log(arr);   [ undefined, undefined, undefined, undefined ]
复制代码
复制代码

一个类数组对象转换为一个真正的数组,必须具备以下条件:
1、该类数组对象必须具有 length 属性,用于指定数组的长度。如果没有 length 属性,那么转换后的数组是一个空数组。

2、该类数组对象的属性名必须为数值型或字符串型的数字 ( 该类数组对象的属性名可以加引号,也可以不加引号)

将Set结构的数据转换为真正的数组:

let arr = [12,45,97,9797,564,134,45642]
let set = new Set(arr)
console.log(Array.from(set))  // [ 12, 45, 97, 9797, 564, 134, 45642 ]

Array.from 还可以接受第二个参数,作用类似于数组的 map 方法,用来对每个元素进行处理,将处理后的值放入返回的数组。

复制代码
复制代码
let arr = [12,45,97,9797,564,134,45642]
let set = new Set(arr)
console.log(Array.from(set, item => item + 2)) // [14, 47, 99, 9799, 566, 136, 45644]
console.log(Array.from(set,item => {return item + 2})); //[14, 47, 99, 9799, 566, 136, 45644]

 // 快速创建一个1~20的数组
 let arr = Array.from({ length: 20 }, (item, index) => { return item = index + 1 })
 console.log(arr);  // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]

        // 模拟生成 1万条数据,利用了 Array.from 来快速生成数据
        const originNews = Array.from(
            { length: 10000 },
            (v, k) => ({ content: `新闻${k}` })
        )
        console.log(originNews);
复制代码
复制代码

将字符串转换为数组元素

let  str = 'hello world!';
console.log(Array.from(str)) // ["h", "e", "l", "l", "o", " ", "w", "o", "r", "l", "d", "!"]

浅拷贝一个数组(多维浅拷贝,单层深拷贝)

复制代码
复制代码
        let arr =  [12, 45, 47, 56, 213, 4654, 154]
        let newarr = Array.from(arr)
        console.log(newarr); //[12, 45, 47, 56, 213, 4654, 154]
        arr.length = 3
        console.log(arr); //[12, 45, 47]
        console.log(newarr); //[12, 45, 47, 56, 213, 4654, 154]
复制代码
复制代码

原文链接

posted on   漫思  阅读(82)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 没有源码,如何修改代码逻辑?
· NetPad:一个.NET开源、跨平台的C#编辑器
历史上的今天:
2020-12-29 js将手机号中间四位变成*号
2020-12-29 取出字符串中的所有数字
2020-12-29 js中字节B转化成KB,MB,GB
2020-12-29 数组去重的几种方法
2020-12-29 最全的常用正则表达式大全——包括校验数字、字符、一些特殊的需求等等
2020-12-29 jQuery滚动条回到顶部或指定位置

导航

< 2025年2月 >
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 1
2 3 4 5 6 7 8
点击右上角即可分享
微信分享提示