首页 > 其他分享 >Array.from()

Array.from()

时间:2024-12-29 23:41:48浏览次数:5  
标签:arr console length let 数组 Array

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]
复制代码

原文链接

标签:arr,console,length,let,数组,Array
From: https://www.cnblogs.com/sexintercourse/p/18639817

相关文章

  • 请手动实现Array.prototype.reduce的方法
    Array.prototype.reduce方法接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始缩减,最终为一个值。以下是一个手动实现的reduce方法的示例:Array.prototype.myReduce=function(callback,initialValue){//如果没有提供初始值,则将数组的第一个元素作为初始......
  • 一维数组、多维数组、Array(deepToString sort fill binarySearch)方法2024122620241
    数组20241226[数组详情](深入理解Java数组-静默虚空-博客园)什么是数组:数组是相同类型数据的有序集合注意:必须是相同数据数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成其中,每一个数据称作一个数组元素。每个数组元素可以通过一个下标来访问......
  • Extjs中Ext.Array 方法的使用
    1.Ext.Array.clean(arr);过滤数组中的空元素vararr=[1,"",2,"",3];Ext.clean(arr);//[1,2,3]2.Ext.Array.clone(arr);可以克隆数组,对象,dom节点和日期数据,以避免保持旧的指向vararr=[1,,2,3];Ext.clone(arr)3.Ext.Array.contains(arr,items);检查此数组是否包含......
  • UE4.27, 揣摩源码, 序列化 (一) FArrayReader, FArrayWriter
    1.从ArrayReader.h和ArrayWriter.h开始1.1.SVO为了减少误解,介绍一下SVO这里的read和write的主词都是array,宾语都是memory所以前者是从内存读出array,后者是将array写入内存1.2.关键继承关系FArrayReader,FArrayWriterc......
  • Postgres 的 Array 类型
    Postgres的Array类型|Id|Title|DateAdded|SourceUrl|PostType|Body|BlogId|Description|DateUpdated|IsMarkdown|EntryName|CreatedTime|IsActive|AutoDesc|AccessPermission||-------------|-------------|-------------|-------------|......
  • Array Collapse
    前言调\(C\)快魔怔了,还是先来打这个思路方法\(1\):笛卡尔树看到这种类\(\rm{RMQ}\)问题直接一个笛卡尔树起手,恰好\(p\)是不重的,那么更方便了啊搞出树树挖下性质例如样例中的42413你注意到每次删除操作相当于选择一个键值段,然后只保留这一段的根节......
  • 19. 说说CopyOnWriteArrayList
    CopyOnWriteArrayList是Java并发包中提供的一个并发容器。CopyOnWriteArrayList相当于线程安全的ArrayList,CopyOnWriteArrayList使用了一种叫写时复制的方法,当有新元素add到CopyOnWriteArrayList时,先从原有的数组中拷贝一份出来,然后在新的数组做写操作,写完之后,再将原来的数组引用......
  • ES7 新增方法:Array.prototype.some、Array.prototype.every
    在前端开发中,我们经常需要对数组进行操作,如查找符合条件的元素、检查是否所有元素都满足条件等。ES7新增了两个方法:Array.prototype.some和Array.prototype.every,可以帮助我们更加简洁地完成这些任务。本文主要介绍这两个方法的用法及其相关知识。 Array.prototype.someArr......
  • js数组-实例方法:Array.prototype.entries,Array.prototype.every,Array.prototype.fill
    Array.prototype.entries()entries()方法返回一个新的数组迭代器对象,该对象包含数组中每个索引的键/值对语法entries()返回值一个新的可迭代迭代器对象Array.prototype.myEntries()Array.prototype.myEntries=function(){constnewThis=[]for(leti......
  • Arrays.asList() 详解
    【1.要点】该方法是将数组转化成List集合的方法。Listlist=Arrays.asList("a","b","c");注意:(1)该方法适用于对象型数据的数组(String、Integer...)(2)该方法不建议使用于基本数据类型的数组(byte,short,int,long,float,double,boolean)(3)该方法将数组与List列表链接起来:当更新其......