需要知道的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中文网其他相关文章!

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

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

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

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

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

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

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

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

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

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

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