Rumah hujung hadapan web tutorial js 需要知道的JS数组之Array.from

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

Sep 08, 2020 pm 01:21 PM
tatasusunan 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]复制代码
Salin selepas log masuk

这是我们平时最常用的功能,写这些示例的时候我还奇怪:为什么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复制代码
Salin selepas log masuk

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

3. 数组去重

function unique(arr){
    return Array.from(new Set(arr))
}复制代码
Salin selepas log masuk

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

4. from的其他用法

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

Array.from({length:2},(val,index)=>index)                        //[0,1]复制代码
Salin selepas log masuk

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

Array.from({length:3},(val,index)=>index*10)                     //[0,10,20]复制代码
Salin selepas log masuk

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

let testArr=Array(3).fill({})
testArr[0]===testArr[1]                                         //true复制代码
Salin selepas log masuk

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

let testArrb=Array.from({length:3},()=>({}))
testArrb[0]===testArrb[1]                                       //false复制代码
Salin selepas log masuk

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

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
};复制代码
Salin selepas log masuk

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

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

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

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

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

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

Atas ialah kandungan terperinci 需要知道的JS数组之Array.from. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk mengalih keluar elemen dari tatasusunan es6 Bagaimana untuk mengalih keluar elemen dari tatasusunan es6 Jan 11, 2023 pm 03:51 PM

Kaedah: 1. Gunakan shift() untuk memadam elemen pertama, sintaksnya ialah "array.shift()"; 2. Gunakan pop() untuk memadam elemen terakhir, sintaksnya ialah "array.pop()"; Gunakan splice() untuk memadamkan Elemen di mana-mana kedudukan, sintaksnya ialah "array.splice(position, number)" 4. Gunakan panjang untuk memadam elemen N terakhir, sintaks ialah "array.length=original array length-N"; ; 5. Tetapkan tatasusunan kosong "[ ]" untuk mengosongkan elemen 6. Gunakan padam untuk memadamkan elemen pada subskrip yang ditentukan.

Bagaimana untuk menukar rentetan kepada tatasusunan dalam javascript Bagaimana untuk menukar rentetan kepada tatasusunan dalam javascript Nov 23, 2022 pm 07:28 PM

3 kaedah penukaran: 1. Gunakan split() untuk memisahkan rentetan yang diberikan kepada tatasusunan rentetan, sintaksnya ialah "str.split (pemisah, panjang maksimum tatasusunan)" 2. Gunakan operator pengembangan "... ", boleh diulang objek rentetan, tukarkannya kepada tatasusunan aksara, sintaks "[...str]" 3. Gunakan Array.from() untuk menukar rentetan itu kepada tatasusunan, sintaks "Array.from(str) ".

Bolehkah tatasusunan js ditukar kepada tatasusunan php? Bolehkah tatasusunan js ditukar kepada tatasusunan php? Jun 02, 2023 am 10:06 AM

Tatasusunan js boleh ditukar kepada tatasusunan php Kaedah operasi ialah: 1. Cipta fail sampel php 2. Gunakan sintaks "JSON.stringify()" untuk menukar tatasusunan js kepada rentetan dalam format JSON; Gunakan sintaks "json_decode()" "Tukar rentetan format JSON kepada tatasusunan PHP. Parameter benar ditambahkan di sini, yang bermaksud bahawa rentetan format JSON ditukar kepada tatasusunan bersekutu PHP.

Bagaimana untuk mendapatkan panjang tatasusunan dalam js Bagaimana untuk mendapatkan panjang tatasusunan dalam js Jun 20, 2023 pm 05:33 PM

Mendapatkan panjang tatasusunan dalam JS adalah sangat mudah Setiap tatasusunan mempunyai sifat panjang, yang mengembalikan panjang maksimum tatasusunan, iaitu nilainya bersamaan dengan nilai subskrip maksimum ditambah 1. Oleh kerana subskrip berangka mestilah kurang daripada 2^32-1, nilai maksimum atribut panjang adalah sama dengan 2^32-1. Kod berikut mentakrifkan tatasusunan kosong, dan kemudian memberikan nilai kepada elemen dengan indeks sama dengan 100, kemudian sifat panjang mengembalikan 101. Oleh itu, atribut panjang tidak boleh mencerminkan bilangan sebenar elemen tatasusunan.

Terdapat beberapa cara untuk memadamkan elemen daripada tatasusunan js Terdapat beberapa cara untuk memadamkan elemen daripada tatasusunan js Aug 02, 2023 am 10:09 AM

Terdapat 4 cara untuk memadam elemen daripada tatasusunan js, iaitu: 1. Gunakan splice;

Pengisihan tatasusunan JS: cara menggunakan kaedah sort(). Pengisihan tatasusunan JS: cara menggunakan kaedah sort(). Dec 27, 2023 pm 03:40 PM

Kaedah Array.prototype.sort() JavaScript digunakan untuk mengisih elemen tatasusunan. Kaedah ini disusun mengikut tempatnya, iaitu, ia mengubah suai tatasusunan asal dan bukannya mengembalikan tatasusunan diisih baharu. Secara lalai, kaedah sort() mengisih rentetan mengikut nilai titik kod Unicode mereka. Ini bermakna ia digunakan terutamanya untuk mengisih rentetan dan nombor, bukannya untuk mengisih objek atau jenis data kompleks lain.

Apakah kaedah untuk mengalih keluar pendua daripada tatasusunan js? Apakah kaedah untuk mengalih keluar pendua daripada tatasusunan js? Aug 09, 2023 pm 04:47 PM

Kaedah untuk menyahduplikasi tatasusunan js termasuk menggunakan Set, menggunakan indexOf, menggunakan termasuk, menggunakan penapis dan menggunakan mengurangkan. 1. Gunakan Set, yang dicirikan oleh fakta bahawa elemen dalam set tidak akan diulang 2. Gunakan indexOf untuk mengembalikan kedudukan indeks pertama elemen yang ditentukan dalam tatasusunan 3. Penggunaan termasuk untuk menentukan sama ada elemen sudah; wujud dalam tatasusunan 4. Gunakan penapis untuk menapis elemen 5. Gunakan pengurangan untuk memampatkan elemen dalam tatasusunan, dsb.

Bagaimana untuk mencari panjang dan jumlah elemen tatasusunan dalam JavaScript Bagaimana untuk mencari panjang dan jumlah elemen tatasusunan dalam JavaScript Sep 20, 2022 pm 02:11 PM

Dalam JavaScript, anda boleh menggunakan atribut panjang untuk mendapatkan panjang tatasusunan, sintaks ialah "objek.length tatasusunan" anda boleh menggunakan fungsi reduce() atau reduceRight() untuk mencari jumlah elemen, sintaksnya ialah "; arr.reduce(fungsi f(pra,curr){ return pra curr})" atau "arr.reduceRight(fungsi f(pra,curr){return pra curr})".

See all articles