.
O
K
A
Y
A

简单的js练习

No.1

var arr = [{ label: '男', value: 1 }, { label: '女', value: 0 }]

function f(arr) {
  // 写代码,得到
  const obj = {}
  arr.forEach((item) => {
    obj[item.value] = item.label
  })
  return obj
}
var obj = f(arr)
console.log(obj)
// obj = {'1': '男', '0': '女'}

No.2

var arr = [{ label: '男', value: 1 }, { label: '女', value: 0 }]

function f(arr) {
  // 写代码,得到
  return arr.map(item => item.label)
}
var arr2 = f(arr)
console.log(arr2)
// arr2 = ['男', '女']

No.3


// 如果A的pid == B的id
// A是B的下属

// 如果A的pid == B的pid
// A和B是同事

var data = [
  { id: '01', name: '张大大', pid: '', job: '项目经理' },
  { id: '02', name: '小亮', pid: '01', job: '产品leader' },
  { id: '03', name: '小美', pid: '01', job: 'UIleader' },
  { id: '04', name: '老马', pid: '01', job: '技术leader' },
  { id: '05', name: '老王', pid: '01', job: '测试leader' },
  { id: '06', name: '老李', pid: '01', job: '运维leader' },
  { id: '07', name: '小丽', pid: '02', job: '产品经理' },
  { id: '08', name: '大光', pid: '02', job: '产品经理' },
  { id: '09', name: '小高', pid: '03', job: 'UI设计师' },
  { id: '10', name: '小刘', pid: '04', job: '前端工程师' },
  { id: '11', name: '小华', pid: '04', job: '后端工程师' },
  { id: '12', name: '小李', pid: '04', job: '后端工程师' },
  { id: '13', name: '小赵', pid: '05', job: '测试工程师' },
  { id: '14', name: '小强', pid: '05', job: '测试工程师' },
  { id: '15', name: '小涛', pid: '06', job: '运维工程师' }
]

// 问题1. 找出 与 小刘 处于统一领导下的同事
function f(data, name) {
  // 完成代码
  const arr = []
  data.forEach(item => {
    if (item.name === name) {
      const pid = item.pid
      data.forEach(item => {
        if (item.pid === pid) {
          arr.push(item)
        }
      })
    }
  })
  return arr
}
const arr = f(data, '小刘')
console.log(arr) //
//  [{id:"10", name: "小刘", pid:"04", job: "前端工程师"},
//  {id:"11", name: "小华", pid:"04", job: "后端工程师"},
//  {id:"12", name: "小李", pid:"04", job: "后端工程师"}]

// 问题2. 找出 小亮 的所有下属
function f2(data, name) {
  // 完成代码
  const arr = []
  data.forEach(item => {
    if (item.name === name) {
      const id = item.id
      data.forEach(item => {
        if (item.pid === id) {
          arr.push(item)
        }
      })
    }
  })
  return arr
}
const arr2 = f2(data, '小亮')
console.log(arr2) //
// [{id:"07", name: "小丽", pid:"02", job: "产品经理"},
// {id:"08", name: "大光", pid:"02", job: "产品经理"}]

No.4

var obj = { label: '男', value: 1, age: 18 }

function f(obj) {
  // 写代码,得到
  const arr = []
  for (const i in obj) {
    arr.push(obj[i])
  }
  return arr
}
var arr = f(obj)
console.log(arr)
// arr = ['男', '1', '18'] // 所有的属性值取出来,保存在数组中

posted @ 2022-12-21 20:09  三井绫子  阅读(17)  评论(0)    收藏  举报