首页 web前端 js教程 需要知道的JS数组之Array.from

需要知道的JS数组之Array.from

Sep 08, 2020 pm 01:21 PM
js数组

需要知道的JS数组之Array.from

相关学习推荐:javascript视频教程

前言

从去年发现字符串的replace方法有很多神奇用法的时候,就想做这个系列,但是一直没空,也没有想到很好的名字,就搁置了。上周五刷题的时候看评论有个解决方法是用Array.from一行解决,而且效率还挺高的。于是啃了一下文档和博客,搞清楚了之后就想正好可以开始这个系列了。而且数组是我们开发中最常用的数据结构之一,作为生成数组的方法之一,以from开始也蛮意思。系列名字就先凑合这么叫吧。

  • 基础语法

定义:from() 方法用于通过拥有 length 属性的对象或可迭代的对象来返回一个数组。

语法:Array.from(object, mapFunction, thisValue)

参数 描述

object

必需,要转换为数组的对象。

mapFunction

可选,数组中每个元素要调用的函数。

thisValue

可选,映射函数(mapFunction)中的 this 对象。

  • 示例用法

1. 将类数组转化为数组

Array.from('hello')                        //["h", "e", "l", "l", "o"]
Array.from(new Set(['name','age']))        //["name", "age"]
Array.from({name:'lgc',age:25})            //[]
let map=new Map()
map.set('name','lgc')
map.set('age',25)
Array.from(map)                            //[["name", "lgc"],["age", 25]]
function test(){
    console.log(Array.from(arguments))
}
test(1,2,3)                                //[1, 2, 3]复制代码
登录后复制

这是我们平时最常用的功能,写这些示例的时候我还奇怪:为什么map能转成数组而object只能转为空数组。当我查看菜鸟教程,看到上述定义我才明白。object既没有length也不是可迭代对象,我之前以为object也是可迭代对象,毕竟都可以用for-in嘛。但其实es6的object不是可迭代对象,这里不多赘述,有兴趣的同学可以去查一下。

2. 数组深拷贝(一行代码)

function clone(arr){
    return Array.isArray(arr) ? Array.from(arr, clone):arr
}
let arrayA=[[1,2],[3,4]]
let arrayB=clone(arrayA)
arrayA===arrayB                                  //false
arrayA[0]===arrayB[0]                            //false复制代码
登录后复制

这里主要用到了Array.from的第二个参数mapFunction,mapFunction默认传两个参数,数组的值和下标。

3. 数组去重

function unique(arr){
    return Array.from(new Set(arr))
}复制代码
登录后复制

这也是from最基本,也是我们最常用的功能之一。

4. from的其他用法

再看一遍from定义:from() 方法用于通过拥有 length 属性的对象或可迭代的对象来返回一个数组。拥有length就行?试一试

Array.from({length:2},(val,index)=>index)                        //[0,1]复制代码
登录后复制

可以,那他有什么用呢?第一,像上面代码,可以很方便生成在一定范围,有一定规则的数组

Array.from({length:3},(val,index)=>index*10)                     //[0,10,20]复制代码
登录后复制

第二,数组的初始化。比如你想生成指定长度的对象数组。第一反应是什么?fill吗?

let testArr=Array(3).fill({})
testArr[0]===testArr[1]                                         //true复制代码
登录后复制

这里的每个对象其实都是同一个,你修改一个其他自然会跟着改变,但很多时候我们需要的并不是这样的。

let testArrb=Array.from({length:3},()=>({}))
testArrb[0]===testArrb[1]                                       //false复制代码
登录后复制

这两个方法可以根据需求使用。

5. from的进阶用法

上面的内容其实层层递进下来都是为了更好的理解下面的解题思路。

LeetCode第867题:

给定一个矩阵 A, 返回 A 的转置矩阵。

矩阵的转置是指将矩阵的主对角线翻转,交换矩阵的行索引与列索引。

示例 1: 输入:[[1,2,3],[4,5,6],[7,8,9]] 输出:[[1,4,7],[2,5,8],[3,6,9]] 示例 2: 输入:[[1,2,3],[4,5,6]] 输出:[[1,4],[2,5],[3,6]]

当时第一反应这就不是索引互换吗?贼简单。于是写了如下代码

var transpose = function(A) {
    let x=A.length
    let y=A[0].length
    for(let i=0;i<x;i++){
        for(let j=0;j<y;j++){
            if(j-i>0){
                [A[i][j],A[j][i]]=[A[j][i],A[i][j]]
            }
        }
    }
    return A
};复制代码
登录后复制

执行代码:通过,提交:失败。卧槽?看一下错误提示,发现忽略了示例2这种,“长宽”不等的情况。转换思路,内外循环翻转。最外循环每执行一次即一列当做行。执行,通过。

不过这版看起来太捞了,而且执行时间太慢。但毕竟自己实现了,可以去评论区找一下其他思路。

下面这个就是看评论区大神实现,第一次都没看懂。

var transpose = function(A) {    return Array.from({length:A[0].length},(_v,i)=>A.map(v=>v[i]))};复制代码
登录后复制

{length:A[0].length},是以给定矩阵的宽作为转置矩阵的长,为了满足“拥有 length 属性的对象”这一条件。(_v,i)=>A.map(v=>v[i]),取给定矩阵的列作为转置矩阵的行。核心思路和我第二版是一样的,但是实现方式和技巧就秀太多了。而且执行时间也较短,膜拜大神。

想了解更多编程学习,敬请关注php培训栏目!

以上是需要知道的JS数组之Array.from的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1662
14
CakePHP 教程
1418
52
Laravel 教程
1311
25
PHP教程
1261
29
C# 教程
1234
24
es6 数组怎么移除元素 es6 数组怎么移除元素 Jan 11, 2023 pm 03:51 PM

方法:1、用shift()删除第一个元素,语法“数组.shift()”;2、用pop()删除最后一个元素,语法“数组.pop()”;3、用splice()删除任意位置的元素,语法“数组.splice(位置,个数)”;4、用length删除尾部的N个元素,语法“数组.length=原数组长度-N”;5、直接赋予空数组“[]”来清空元素;6、用delete删除指定下标的一个元素。

javascript如何将字符串转为数组 javascript如何将字符串转为数组 Nov 23, 2022 pm 07:28 PM

3种转换方法:1、使用split(),可将给定字符串拆分为字符串数组,语法“str.split(分隔符,数组最大长度)”;2、利用扩展运算符“...”,可迭代字符串对象,将其转为字符数组,语法“[...str]”;3、使用Array.from(),可将字符串转为数组,语法“Array.from(str)”。

js数组可以转化成php数组吗 js数组可以转化成php数组吗 Jun 02, 2023 am 10:06 AM

js数组可以转化成php数组,其操作方法是:1、建立php示例文件;2、使用语法“JSON.stringify()”将js数组转化为JSON格式的字符串;3、使用语法“json_decode()”将JSON格式字符串转为PHP数组,此处添加了参数true,表示将JSON格式字符串转换成PHP关联数组。

js获取数组长度的方法 js获取数组长度的方法 Jun 20, 2023 pm 05:33 PM

在 JS 中获取数组长度非常简单,每个数组都有一个 length 属性,该属性返回数组的最大长度,即其值等于最大下标值加 1。由于数字下标必须小于 2^32-1,所以 length 属性最大值等于 2^32-1。下面代码定义了一个空数组,然后为下标等于 100 的元素赋值,则 length 属性返回 101。因此,length 属性不能体现数组元素的实际个数。

js数组删除某个元素有几种方法 js数组删除某个元素有几种方法 Aug 02, 2023 am 10:09 AM

js数组删除某个元素有4种方法,分别是:1、使用splice;2、使用filter;3、使用pop方法和shift;4、使用delete关键字。

JS数组排序:sort()方法怎么用 JS数组排序:sort()方法怎么用 Dec 27, 2023 pm 03:40 PM

JavaScript的Array.prototype.sort()方法用于对数组的元素进行排序。此方法是就地排序,也就是说,它修改原始数组,而不是返回一个新的排序数组。默认情况下,sort()方法按照字符串Unicode码点值进行排序。这意味着它主要用于字符串和数字的排序,而不是用于对象或其他复杂数据类型的排序。

js数组去重的方法有哪些 js数组去重的方法有哪些 Aug 09, 2023 pm 04:47 PM

js数组去重的方法有使用Set、使用indexOf、使用includes、使用filter和使用reduce。1、使用Set,特点是集合中的元素不会重复;2、使用indexOf,可以返回指定元素在数组中的第一个索引位置;3、使用includes,可以用来判断一个元素是否已经存在于数组中;4、使用filter,可以用来筛选元素;5、使用reduce,可以将数组中的元素压缩等等。

JavaScript怎么求数组长度和元素之和 JavaScript怎么求数组长度和元素之和 Sep 20, 2022 pm 02:11 PM

JavaScript中,可利用length属性来获取数组长度,语法“数组对象.length”;可使用reduce()或reduceRight()函数来求元素之和,语法“arr.reduce(function f(pre,curr){return pre+cur})”或“arr.reduceRight(function f(pre,curr){return pre+cur})”。

See all articles