zoukankan      html  css  js  c++  java
  • find 和 map的应用

    find

    find() 方法返回通过测试(函数内判断)的数组的第一个元素的值。

    find() 方法为数组中的每个元素都调用一次函数执行:

    • 当数组中的元素在测试条件时返回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。
    • 如果没有符合条件的元素返回 undefined

    注意: find() 对于空数组,函数是不会执行的。

    注意: find() 并没有改变数组的原始值。

    1.找到对应的值

        
    let week = 2
    let weekName
    = this.getWeekName(week) weeksOptions: [ {value: '1', name: '周一'}, {value: '2', name: '周二'}, {value: '3', name: '周三'}, {value: '4', name: '周四'}, {value: '5', name: '周五'}, {value: '6', name: '周六'}, {value: '7', name: '周日'} ], getWeekName (week) { return this.weeksOptions.find(item => { return item.value === week + '' }).name },

     2.筛选出符合条件的,过滤掉

              let thisTime = this.addTimeForm.timeList.find(item => {
                return ((this.beginTime <= item.bt && this.endTime >= item.bt) || (this.endTime >= item.et && this.beginTime <= item.et) || (this.endTime <= item.et && this.beginTime >= item.bt))
              })
              console.log('thisTime:', thisTime)
              if (thisTime) {
                this.sentMsg('所选时间段已存在')
                return
              } else {
                console.log('thisTime:', thisTime)
              }

    map

    map() 方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值。

    map() 方法按照原始数组元素顺序依次处理元素。

    注意: map() 不会对空数组进行检测。

    注意: map() 不会改变原始数组。

               this.table1.array = res.body.data.advTimeList.map((item, index) => {
                  item.weekName = this.getWeekName(item.week)
                  item.operation = {
                    id: index + 'operation'
                  }
                })
  • 相关阅读:
    redis持久化的方式RDB 和 AOF
    centos7搭建mysql-5.7.22主从复制
    Vue项目上线后刷新报错404问题(apache,nginx,tomcat)
    Zabbix监控华为交换机
    Zabbix数据库清理历史数据
    MySQL增删改查基本语句
    什么是SQL注入式攻击?
    .NET面试题(二)
    .NET面试题(一)
    .NET面试题(三)
  • 原文地址:https://www.cnblogs.com/benbendu/p/12844967.html
Copyright © 2011-2022 走看看