编程语言的JavaScript中怎么重组数组?

    作者:课课家教育更新于: 2019-08-27 10:55:49

    大神带你学编程,欢迎选课

    来一个老生常谈的话题,Javascript中,数组如何去重?不论什么java应用服务器实质都是内置了某个版本的JDk。主流的JDK是Sun公司发布的JDK,除了Sun之外,还有很多公司和组织都开发了自己的JDK,例如,IBM公司开发的JDK,BEA公司的Jrocket,还有GNU组织开发的JDK。

    关于如何去除一个给定数组中的重复项,应该是 Javascript 面试中最常见的一个问题了,最常见的方式有三种:Set、Array.prototype.filter 以及 Array.prototype.reduce,对于只有简单数据的数组来讲,我最喜欢 Set,没别的,就是写起来简单。

    编程语言的JavaScript中怎么重组数组_编程语言_Java_Javascript_课课家

    关于如何去除一个给定数组中的重复项,应该是 Javascript 面试中最常见的一个问题了,最常见的方式有三种:Set、Array.prototype.filter 以及 Array.prototype.reduce,对于只有简单数据的数组来讲,我最喜欢 Set,没别的,就是写起来简单。

    1. const originalArray = [1, 2, '咩', 1, 'Super Ball''咩''咩''Super Ball', 4] 
    2. const bySet = [...new Set(originalArray)] 
    3. const byFilter = originalArray.filter((item, index) => originalArray.indexOf(item) === index)  
    4. const byReduce = originalArray.reduce((unique, item) => unique.includes(item) ? unique : [...unique, item], []) 

    使用 Set

    先让我们来看看 Set 到底是个啥

    1. Set 对象允许你存储任何类型的唯一值,无论是原始值或者是对象引用。 
    2. https://developer.mozilla.org... 
    • 首先,Set 中只允许出现唯一值
    • 唯一性是比对原始值或者对象引用

    const bySet = [...new Set(originalArray)] 这一段的操作,我们将它拆分来看:

    1. const originalArray = [1, 2, '咩', 1, 'Super Ball''咩''咩''Super Ball', 4]  
    2. const uniqueSet = new Set(originalArray) 
    3. // 得到 Set(5) [ 1, 2, "咩""Super Ball", 4 ] 
    4. const bySet = [...uniqueSet] 
    5. // 得到 Array(5) [ 1, 2, "咩""Super Ball", 4 ] 

    在将 Set 转为 Array 时,也可以使用 Array.from(set)。

    使用 Array.prototype.filter

    要理解 filter 方法为什么可以去重,需要关注一下另一个方法 indexOf

    1. indexOf()方法返回在数组中可以找到一个给定元素的第一个索引,如果不存在,则返回 -1。 
    2. https://developer.mozilla.org... 
    1. const beasts = ['ant''bison''camel''duck''bison']; 
    2. console.log(beasts.indexOf('bison')); 
    3. // expected output: 1 
    4. // start from index 2 
    5. console.log(beasts.indexOf('bison', 2)); 
    6. // expected output: 4 
    7. console.log(beasts.indexOf('giraffe')); 
    8. // expected output: -1 
    1. filter() 方法创建一个新数组, 其包含通过所提供函数实现的测试的所有元素。 
    2. https://developer.mozilla.org... 

    filter 方法接受两个参数:

    • 第一个参数:一个回调函数, filter 会将数据中的每一项都传递给该函数,若该函数返回 真值,则数据保存,返回 假值,则数据将不会出现在新生成的数据中
    • 第二个参数:回调函数中 this 的指向

    我们将上面的去重方法按下面这样重写一下,就可以看清整个 filter 的执行过程了。

    1. const originalArray = [1, 2, '咩', 1, 'Super Ball''咩''咩''Super Ball', 4] 
    2. const table = [] 
    3. const byFilter = originalArray.filter((item, index) => { 
    4.   // 如果找到的索引与当前索引一致,则保留该值 
    5.   const shouldKeep = originalArray.indexOf(item) === index 
    6.   table.push({ 
    7.     序号: index
    8.     值: item, 
    9.     是否应该保留: shouldKeep ? '保留' : '删除' 
    10.   }) 
    11.   return shouldKeep 
    12. })  
    13. console.log(byFilter) 
    14. console.table(table

    使用 Array.prototype.reduce

    1. reduce() 方法对数组中的每个元素执行一个由您提供的 reducer 函数(升序执行),将其结果汇总为单个返回值。 
    2. https://developer.mozilla.org... 

    Array.prototype.reduce 方法接受两个参数:

    • Callback:回调函数,它可以接收四个参数
    1. Accumulator:累计器,这个其实是让很多人忽略的一点,就是,累计器其实可以是任何类型的数据
    2. Current Value:当前值
    3. Current Index:当前值的索引
    4. Source Array:源数组
    • Initial Value:累计器的初始值,就跟累计器一样,这个参数也总是被绝大多数人忽略

    就像 filter 章节一样,我们来看看 reduce 的执行过程:

    1. const originalArray = [1, 2, '咩', 1, 'Super Ball''咩''咩''Super Ball', 4] 
    2. const byReduce = originalArray.reduce((unique, item, index, source) => { 
    3.   const exist = unique.includes(item) 
    4.   const next = unique.includes(item) ? unique : [...unique, item] 
    5.   console.group(`遍历第 ${index} 个值`) 
    6.   console.log('当前累计器:'unique
    7.   console.log('当前值:', item) 
    8.   console.log('是否已添加进累计器?', exist) 
    9.   console.log('新值'next
    10.   console.groupEnd() 
    11.   return next 
    12. }, []) 
       对于新语言的设计,Sun公司研发人员并没有开发一种全新的语言,而是根据嵌入式软件的要求,对C++进行了改造,去除了留在C++的一些不太实用及影响安全的成分,并结合嵌入式系统的实时性要求,开发了一种称为Oak的面向对象语言。

课课家教育

未登录