js數(shù)組與對(duì)象常用操作方法

一暑始、Js相關(guān)數(shù)組操作

  1. 數(shù)組去除相同的
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. 數(shù)組添加數(shù)數(shù)據(jù)
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. 數(shù)組反轉(zhuǎn)
   reversePeople(array) {
      let newArr = [];
      for (let i = array.length - 1; i >= 0; i--) {
        newArr[newArr.length] = array[i];
      }
      return newArr;
    },
  1. 打亂數(shù)組排序
let arr = [1,2,3,4,5]
arr.sort(() => Math.random() - 0.5);
//隨機(jī)輸出一個(gè)排序打亂的數(shù)組
  1. 取數(shù)組的前幾個(gè)
let arr = [1,2,3,4]
arr.slice(0,2)
//輸出arr = [1,2]
  1. 數(shù)組扁平化
flatten(arr) {
    return arr.join(',').split(',').map(function(item) {
        return parseInt(item);
    })
}
  1. 遍歷對(duì)象取key值
let obj = res.data.record
let arrOne = [] //處理為數(shù)組
let finish = [] //完成
let remain = [] //未完成
let arrName = [] //鎮(zhèn)的名字
//遍歷對(duì)象
Object.getOwnPropertyNames(obj).forEach((key, index) => {
      arrOne.push(obj[key])
      arrName[index] = key
})
//遍歷數(shù)組 組合數(shù)組
arrOne.forEach((key, index) => {
    finish[index] = key.finish
    remain[index] = key.remain
})
  1. 數(shù)組轉(zhuǎn)換為對(duì)象弥喉,并且把數(shù)組處理成字符串
 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. 將對(duì)象的數(shù)據(jù)拼接成數(shù)組的數(shù)據(jù)并且取到不同的值。
  let arr = res.data.record.caseMap
        let arrOne = []
      //遍歷了對(duì)象蚂四,添加圖片路徑進(jìn)數(shù)組
        Object.getOwnPropertyNames(arr).forEach((key, index) => {
          arr[key].src = require(`@/assets/home/pic${index}.png`)
          arrOne.push(arr[key])
        })

   let data = res.data.record
        //業(yè)務(wù)類型
       //(data.caseSourceMap)
        let arr = []
        let arrOne = []
        Object.getOwnPropertyNames(data.caseSourceMap).forEach((key, index) => {
          arr.push(key)
          arrOne.push(data.caseSourceMap[key])
        })
  1. 當(dāng)數(shù)組不足9項(xiàng)的時(shí)候 補(bǔ)足 9項(xiàng)目。
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 的樹

 // 遞歸  
// 參數(shù)一 原本的樹結(jié)構(gòu),參數(shù)2 id 組合成為的數(shù)組
    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 .遍歷一個(gè)對(duì)象 尋找其尾數(shù)相同的數(shù)組 并且將其拼合成一個(gè)全新的對(duì)象谱醇!

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)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市步做,隨后出現(xiàn)的幾起案子副渴,更是在濱河造成了極大的恐慌,老刑警劉巖全度,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件煮剧,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡将鸵,警方通過查閱死者的電腦和手機(jī)勉盅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來顶掉,“玉大人草娜,你說我怎么就攤上這事⊙魍玻” “怎么了宰闰?”我有些...
    開封第一講書人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵茬贵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我移袍,道長(zhǎng)解藻,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任咐容,我火速辦了婚禮舆逃,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘戳粒。我一直安慰自己路狮,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開白布蔚约。 她就那樣靜靜地躺著奄妨,像睡著了一般。 火紅的嫁衣襯著肌膚如雪苹祟。 梳的紋絲不亂的頭發(fā)上砸抛,一...
    開封第一講書人閱讀 50,084評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音树枫,去河邊找鬼直焙。 笑死,一個(gè)胖子當(dāng)著我的面吹牛砂轻,可吹牛的內(nèi)容都是我干的奔誓。 我是一名探鬼主播,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼搔涝,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼厨喂!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起庄呈,我...
    開封第一講書人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤蜕煌,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后诬留,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體斜纪,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年文兑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了盒刚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡彩届,死狀恐怖伪冰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情樟蠕,我是刑警寧澤贮聂,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布靠柑,位于F島的核電站,受9級(jí)特大地震影響吓懈,放射性物質(zhì)發(fā)生泄漏歼冰。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一耻警、第九天 我趴在偏房一處隱蔽的房頂上張望隔嫡。 院中可真熱鬧,春花似錦甘穿、人聲如沸腮恩。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)秸滴。三九已至,卻和暖如春募判,著一層夾襖步出監(jiān)牢的瞬間荡含,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來泰國(guó)打工届垫, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留释液,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓装处,卻偏偏與公主長(zhǎng)得像误债,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子符衔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容

  • 檢測(cè)數(shù)組方法 isArray()判斷是否是數(shù)組 轉(zhuǎn)換方法 toString()數(shù)組轉(zhuǎn)換字符串方法數(shù)組的 value...
    嗨超兒閱讀 718評(píng)論 0 4
  • 數(shù)組的長(zhǎng)度 數(shù)組的操作方法 插入和刪除 從數(shù)組尾部開始 例子 從數(shù)組頭部開始 例子 任意位置插入找前,修改和刪除 sp...
    饑人谷_Tom閱讀 375評(píng)論 0 1
  • 1)concat方法:不會(huì)改變?cè)瓟?shù)組糟袁,會(huì)返回一個(gè)拼接后的新數(shù)組 2)slice方法:不會(huì)改變?cè)瓟?shù)組判族,會(huì)返回一個(gè)截取...
    puxiaotaoc閱讀 4,756評(píng)論 1 14
  • 首先給大家介紹javascript jquery中定義數(shù)組與操作的相關(guān)知識(shí),具體內(nèi)容如下所示: 1.認(rèn)識(shí)數(shù)組 數(shù)組...
    JamHsiao_aaa4閱讀 1,918評(píng)論 0 2
  • JavaScript一些常用的操作方法 join() 將數(shù)組中所有元素轉(zhuǎn)化為字符串并連接一起项戴,返回最后生成的字符串...
    讀心讀書閱讀 261評(píng)論 0 0