久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

淺談js數(shù)組splice刪除某個元素爬坑

瀏覽:112日期:2024-04-16 15:17:47

先來看下幾個概念:

// splice:返回從原始數(shù)組中刪除的項(如果沒有任何刪除,則返回空數(shù)組) // 當指定2個參數(shù)時,表示刪除 // 當指定3個參數(shù),且第2個參數(shù)為0時表示插入 // 當指定3個參數(shù),且第2個參數(shù)為1時表示替換

本次就拿刪除舉例,本身我們想刪除數(shù)組中的某個指定元素,我們需要知道它所在數(shù)組中的下標,我們可以用 數(shù)組.indexOf獲取它所在的下標,然后拿splice刪除這個元素。

本身是沒問題

代碼如下:

var arr = ['張三','李四','王五','趙六'];// 刪除王五arr.splice(arr.indexOf('王五'),1);

但是。。。。。問題就來了。

如果放到for循環(huán)中,比如循環(huán)數(shù)組,當某個條件成立的時候,我們需要刪除某個指定的元素。

但是循環(huán)中,i每次都是+1的,但是我們刪除某個元素后,下標就變了,相應的位置發(fā)生變化,i的值加一后,就會跳過下一個元素。

坑啊。。。

所以,在刪除某個元素的時候,我們手動把 i的值再減一,這樣就會避免出現(xiàn)跳過某個元素的問題。

例如:循環(huán)數(shù)組,當 DasOperation 屬性值等于 沒變 的時候,從數(shù)組中刪除這條數(shù)據(jù),然后i-1

// 刪除沒有變化的,不傳遞到后臺for (let i = 0; i < this.CurrJobData.Content.length; i += 1) { if (this.CurrJobData.Content[i].DasOperation === ’沒變’) { this.CurrJobData.Content.splice(this.CurrJobData.Content.indexOf(this.CurrJobData.Content[i]), 1); i -= 1;// 必須對i減去1,否則后面的一個元素會被跳過去 }}

好了,為避免更多小伙伴遇坑,貼出來,希望有幫助。

到此這篇關于淺談js數(shù)組splice刪除某個元素爬坑的文章就介紹到這了,更多相關js splice刪除某個元素內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 日日操视频 | 亚欧毛片| 亚洲午夜精品 | 亚洲永久免费 | 97色免费视频 | 2018狠狠干| 亚洲高清视频一区 | 免费99视频 | 夜夜骑首页| 99亚洲精品 | 国产 高清 在线 | 久久久久久一区二区 | 亚洲精品自拍视频 | 国产精品中文字幕在线观看 | 精品免费久久 | 91免费国产 | 国产成人在线免费观看 | 97久久久| 天天综合网91 | 精品在线一区二区 | 国产乱码精品一区二区三区五月婷 | 国产视频三区 | 久久久久成人精品 | 97视频在线 | 亚洲激情一区二区 | 超碰在线播 | 精品国产一区二区三区性色av | www.国产欧美 | 免费av电影网站 | 久久久欧美 | 国产精品日本欧美一区二区三区 | 日日骚视频 | 日本黄色毛片 | 日本国产一区二区 | 精品午夜久久久 | 毛片在线视频 | 欧美激情一区二区 | 超碰人人插 | 成人精品一区二区三区 | 日本精品视频在线观看 | 久久九九国产精品 |