js数组与对象常用操作方法

一、Js相关数组操作

  1. 数组去除相同的
let arr = [1,2,3]
let arr2 = [1,2,3,4,5]
// 输出arr3 =  [4,5]
    arr3 = arr.filter(v => {
          return arr2.indexOf(v) === -1
     });
  1. 数组添加数数据
let arr1 =[{ids:1,name:Emiley},{ids:2,name:bob},{ids:3,name:run}]
//输出 arr2 = [{id:1,ids:1,name:Emiley},{id:2,ids:2,name:bob},{id:3,ids:3,name:run}]
arr1.forEach(ele => {
        if (ids.id) {
          ele.ids= ele.id;
        }
});
  1. 数组反转
   reversePeople(array) {
      let newArr = [];
      for (let i = array.length - 1; i >= 0; i--) {
        newArr[newArr.length] = array[i];
      }
      return newArr;
    },
  1. 打乱数组排序
let arr = [1,2,3,4,5]
arr.sort(() => Math.random() - 0.5);
//随机输出一个排序打乱的数组
  1. 取数组的前几个
let arr = [1,2,3,4]
arr.slice(0,2)
//输出arr = [1,2]
  1. 数组扁平化
flatten(arr) {
    return arr.join(',').split(',').map(function(item) {
        return parseInt(item);
    })
}
  1. 遍历对象取key值
let obj = res.data.record
let arrOne = [] //处理为数组
let finish = [] //完成
let remain = [] //未完成
let arrName = [] //镇的名字
//遍历对象
Object.getOwnPropertyNames(obj).forEach((key, index) => {
      arrOne.push(obj[key])
      arrName[index] = key
})
//遍历数组 组合数组
arrOne.forEach((key, index) => {
    finish[index] = key.finish
    remain[index] = key.remain
})
  1. 数组转换为对象,并且把数组处理成字符串
 list(v) {
let arr = []
v.forEach((ele) => {
    arr.push(ele.caseNo)
})
let arrOne = Object.assign({}, arr)
let ogj = Object.values(arrOne)
let string = JSON.stringify(ogj).replace(/\"/g, '').replace(/\[|]/g, '')
      return string
}
  1. 将对象的数据拼接成数组的数据并且取到不同的值。
  let arr = res.data.record.caseMap
        let arrOne = []
      //遍历了对象,添加图片路径进数组
        Object.getOwnPropertyNames(arr).forEach((key, index) => {
          arr[key].src = require(`@/assets/home/pic${index}.png`)
          arrOne.push(arr[key])
        })

   let data = res.data.record
        //业务类型
       //(data.caseSourceMap)
        let arr = []
        let arrOne = []
        Object.getOwnPropertyNames(data.caseSourceMap).forEach((key, index) => {
          arr.push(key)
          arrOne.push(data.caseSourceMap[key])
        })
  1. 当数组不足9项的时候 补足 9项目。
var  arr = [0,1,2]
var arrThe = [...arr,...ner Array(9-arr.length).fill(0)]
//输出  arrThe  ==>   [ 0,1,2,0,0,0,0,0,0,0]

11 .递归操作两颗树 比较两棵树 只留下 含有的 相同id 的树

 // 递归  
// 参数一 原本的树结构,参数2 id 组合成为的数组
    filterMenu(menuList, menuCode) {
      console.log(menuList, menuCode)
      return menuList.filter(item => {
        return menuCode.indexOf(item.id) > -1
      }).map(item => {
        item = Object.assign({}, item)
        if (item.children) {
          item.children = this.filterMenu(item.children, menuCode)
        }
        return item
      })
    },

12 .遍历一个对象 寻找其尾数相同的数组 并且将其拼合成一个全新的对象!

let wglist = {
            nightPer2: "33.33%",
            userAll3: 6,
            nightPer1: "33.33%",
            userAll2: 6,
            nightPer4: "33.33%",
            userAll5: 6,
            nightPer3: "33.33%",
            userAll4: 6,
            userAll1: 6,
            planDateStr1: "2021-06-08 00:00:00",
            nightPer6: "33.33%",
            nightPer5: "33.33%",
            grdlCode: "3",
            nightPer8: "33.33%",
            nightPer7: "33.33%",
            planDateStr6: "2021-06-13 00:00:00",
            planDateStr7: "2021-06-14 00:00:00",
            planDateStr8: "2021-06-15 00:00:00",
            planDateStr2: "2021-06-09 00:00:00",
            planDateStr3: "2021-06-10 00:00:00",
            planDateStr4: "2021-06-11 00:00:00",
            planDateStr5: "2021-06-12 00:00:00",
            grdCode: "GRD6101150016",
            dayPer5: "66.67%",
            dayPer6: "66.67%",
            dayPer7: "66.67%",
            dayPer8: "66.67%",
            dayPer1: "66.67%",
            userAll7: 6,
            dayPer2: "11.27%",
            userAll6: 6,
            dayPer3: "66.67%",
            dayPer4: "66.67%",
            userAll8: 6,
            dayShift2: 4,
            dayShift3: 4,
            dayShift4: 4,
            dayShift5: 4,
            dayShift1: 4,
            grdName: "油槐街道",
            dayShift6: 4,
            dayShift7: 4,
            dayShift8: 4,
            nightShift1: 2,
            allPer8: "100.00%",
            allPer7: "100.00%",
            allPer6: "100.00%",
            allPer5: "100.00%"
        }
        var resObj = new Array();
        var pattern = /[0-9]$/;
        Object.keys(wglist).forEach((key) => {
            status = pattern.test(key);
            if (status === 'true') {
                var index = key.match(pattern)[0];
                var val = wglist[key];
                if (typeof (resObj[index]) === 'object') {
                    resObj[index][key] = val;
                } else {
                    resObj[index] = new Object();
                    resObj[index][key] = val;
                }
            }
        });
        console.log('resObj', resObj)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容

  • 检测数组方法 isArray()判断是否是数组 转换方法 toString()数组转换字符串方法数组的 value...
    嗨超儿阅读 720评论 0 4
  • 数组的长度 数组的操作方法 插入和删除 从数组尾部开始 例子 从数组头部开始 例子 任意位置插入,修改和删除 sp...
    饥人谷_Tom阅读 380评论 0 1
  • 1)concat方法:不会改变原数组,会返回一个拼接后的新数组 2)slice方法:不会改变原数组,会返回一个截取...
    puxiaotaoc阅读 4,758评论 1 14
  • 首先给大家介绍javascript jquery中定义数组与操作的相关知识,具体内容如下所示: 1.认识数组 数组...
    JamHsiao_aaa4阅读 1,926评论 0 2
  • JavaScript一些常用的操作方法 join() 将数组中所有元素转化为字符串并连接一起,返回最后生成的字符串...
    读心读书阅读 262评论 0 0