javasscript刪除數組的3種方法
1,用shift()方法
shift:刪除原數組第一項,并返回刪除元素的值;如果數組為空則返回undefined
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]
前面的方法只能操作數組開頭和結尾,無法操作中間項,如果要操作中間的項,使用splice方法
3,用splice方法
這個方法很強大,可以對數組任意項進行增加,刪除,替換操作
修改操作:
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
上面例子中,把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
上面例子中,把chaomao中位置2后的0項換成8,9,也就等于添加了兩項
其實,刪除和添加操作都只是splice修改方法的兩種衍生罷了
javasscript刪除對象的方法
js中刪除對象元素用delete操作符
我們來看看一個例子
var p ={
"name": “chaomao”,
"age":45,
"sex":"male"
};
delete p.name
for(var i in p){
console.log(i);//輸出age,sex,name項已經被刪除了
}
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>javascript里面的數組,json對象,動態添加,修改,刪除示例</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js" type="text/javascript"></script>
<script type="text/javascript">
var a = JSON.parse("{\"title\":\"\",\"data\":[]}");
var b = JSON.parse("{\"id\":\"2\"}");
var c = JSON.parse("{\"id\":\"3\"}");
var d = JSON.parse("{\"id\":\"4\"}");
var e = JSON.parse("{\"id\":\"5\"}");
var f = JSON.parse("{\"id\":\"6\"}");
function myObjectPush() {
debugger;
/* javascript里面的數組,json對象,動態添加,修改,
刪除示例 只要適合Javascript的方法都是可以用在JSON對象的數組中的!
所以還有另外的方法splice( )進行crud操作!
*/
//增加屬性
$(a).attr("id", "1");
//增加子對象
a.data.push(b); //數組最后加一條記錄
a.data.push(c);
a.data.push(d);
a.data.unshift(d); //數組最前面加一條記錄
//修改子對象及屬性
a.title = "這是json名字";
//刪除子對象
//json的刪除有很多種,直接用過 delete json對象方式:
delete a.data[1];
a.data.pop(); //刪除最后一項
a.data.shift(); //刪除第一項
a.data.splice(0, 1); //刪除指定子對象,參數:開始位置,刪除個數
//替換不刪除
a.data.splice(1, 0, e, f); //開始位置,刪除個數,插入對象
//替換并刪除 a.data.splice(0, 1, e, f);//開始位置,刪除個數,插入對象
}
</script>
</head>
<body onload="myObjectPush()"></body>
</html>