javasscript刪除數組的3種方法

javascript刪除JSON元素

首先要搞清JSON的數據格式,我這裏所說的JSON都是指javascript中的。

JSON數據是由對象和數組數據結構組成,我們只要學會javascript中對對象和數組的刪除方法即可對JSON項進行刪除操作

javasscript刪除數組的3種方法

1,用shift()方法

shift:刪除原數組第一項,並返回刪除元素的值;如果數組爲空則返回undefined

  • var chaomao=[1,2,3,4,5]
  •  
  • var chaomao.shift() //得到1
  •  
  • alert(chaomao) //[2,3,4,5]
var chaomao=[1,2,3,4,5]

var chaomao.shift() //得到1

alert(chaomao) //[2,3,4,5]

2,用pop()方法

pop:刪除原數組最後一項,並返回刪除元素的值;如果數組爲空則返回undefined

  • var chaomao=[1,2,3,4,5]
  •  
  • var chaomao.pop() //得到5
  •  
  • alert(chaomao) //[1,2,3,4]
var chaomao=[1,2,3,4,5]

var chaomao.pop() //得到5

alert(chaomao) //[1,2,3,4]

前面的方法只能操作數組開頭和結尾,無法操作中間項,如果要操作中間的項,使用splice方法

3,用splice方法

這個方法很強大,可以對數組任意項進行增加,刪除,替換操作

修改操作:

  • var chaomao=[1,2,3,4,5]
  •  
  • chaomao.splice(2,1,8,9)
  •  
  • alert(chaomao) //1,2,8,9,4,5
var chaomao=[1,2,3,4,5]

chaomao.splice(2,1,8,9)

alert(chaomao) //1,2,8,9,4,5

第一個參數是準備操作的數組位置,第二個參數是操作位置後面的數組項數,第三個以後的就是,被替換後的內容

例子就是表示:從chaomao這個數組位置2開始(也就是值爲3的那一項,數組下標從0開始的),位置2後的一項,替換成成8,9

如果把第二個參數改爲2,也就是chaomao.splice(2,2,8,9),也就是說位置2後面的兩項換成8,9,打印出來的結果就是1,2,8,9,5,3和4這2兩項被換掉了

這裏需要說明的是,被替換的項數不一定要和替換的項數相等,1項可以被換成3項,5項也可以被換成2項,基於這個原理,我們就用這個方法來對數組進行添加和刪除操作

 

刪除操作:

  • var chaomao=[1,2,3,4,5]
  •  
  • chaomao.splice(2,1)
  •  
  • alert(chaomao) //1,2,4,5
var chaomao=[1,2,3,4,5]

chaomao.splice(2,1)

alert(chaomao) //1,2,4,5

上面例子中,把chaomao中的位置2後的1項替換成空的,因爲後面沒有內容,結果可以看到,把3這項刪除了

 

添加操作:

  • var chaomao=[1,2,3,4,5]
  •  
  • chaomao.splice(2,0,8,9)
  •  
  • alert(chaomao) //1,2,8,9,3,4,5
var chaomao=[1,2,3,4,5]

chaomao.splice(2,0,8,9)

alert(chaomao) //1,2,8,9,3,4,5

上面例子中,把chaomao中位置2後的0項換成8,9,也就等於添加了兩項

其實,刪除和添加操作都只是splice修改方法的兩種衍生罷了 其他不靠譜的數組刪除方法

之所以說不靠譜,是因爲它沒有真正刪除數組項,而是是把它設置爲空了,項本身的位置還在,數組項數沒變

不靠譜的數組刪除方法1:

  • var chaomao = [1,2,3,4,5];
  •  
  • chaomao[1]=null;
  •  
  • alert(chaomao.length); //5
var chaomao = [1,2,3,4,5];

chaomao[1]=null;

alert(chaomao.length); //5

打印出的項數還是5,並沒有刪除它,只是把chaomao[1]這一項值設爲null,chaomao[1]=undefined,這中方法也是一樣,並沒有刪除數組項

 

不靠譜的數組刪除方法2:

  • var chaomao = [1,2,3,4,5];
  •  
  • delete chaomao[1];
  •  
  • alert(chaomao.length); //5
var chaomao = [1,2,3,4,5];

delete chaomao[1];

alert(chaomao.length); //5

和方法1的結果一樣,並沒有真正刪除它,而只是把這一項設爲undefined

 javascript刪除對象的方法

js中刪除對象元素用delete操作符

我們來看看一個例子

  • var p = {
  • "name": “chaomao”,
  • "age": 45,
  • "sex": "male"
  • };
  •  
  • delete p.name
  • for(var i in p){
  • console.log(i); //輸出age,sex,name項已經被刪除了
  • }
var p = {
      "name": “chaomao”,
      "age": 45,
      "sex": "male"
};

delete p.name
for(var i in p){
console.log(i); //輸出age,sex,name項已經被刪除了
}

javascript刪除JSON元素

前面我們已經會了JS刪除對象和數組的方法 我們下面進對一個具體的JSON數據進行操作

  • var computer = { //這個JSON數據由數組和對象結構組成
  • "cpu": ["intel","AMD"],
  • "harddisk": ["Western Digital","Seagate"],
  • "motherboard": ["ASUS","MSI"]
  • };
var computer = { //這個JSON數據由數組和對象結構組成
      "cpu": ["intel","AMD"],
      "harddisk": ["Western Digital","Seagate"],
      "motherboard": ["ASUS","MSI"]
};

如果我們要刪除CPU裏面裏intel這一個元素,因爲這是數組裏面的一項,所以我們用數組方法

  • computer.cpu.splice(0,1)
  • console.log(computer.cpu) //輸出AMD,intel被刪除了
computer.cpu.splice(0,1)
console.log(computer.cpu) //輸出AMD,intel被刪除了

我們如果想刪除harddisk這一項,因爲它是對象的一項,所以我們要用對象的刪除方法進行操作

text
  • delete computer.harddisk
  • for(var i in computer){
  • console.log(i) //輸出CPU,motherboard,harddisk被刪除了
  • }
delete computer.harddisk
for(var i in computer){
console.log(i) //輸出CPU,motherboard,harddisk被刪除了
}

總結:JSON的主要數據結構是對象和數組,我們只要對相應的項的結構,進行相應的操作方法,就可以方便的刪除JSON元素

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章