JSON 元素的添加刪除

2023-04-17 14:37 更新

JSON本質(zhì)上是JavaScript的對(duì)象,我們可以使用一些JavaScript的操作對(duì)象的方法來對(duì)JSON進(jìn)行元素的添加或者刪除。

數(shù)組結(jié)構(gòu)

使用shift()方法

shift:刪除原數(shù)組第一項(xiàng),并返回刪除元素的值;如果數(shù)組為空則返回undefined

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

使用pop()方法

pop:刪除原數(shù)組最后一項(xiàng),并返回刪除元素的值;如果數(shù)組為空則返回undefined

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

前面的方法只能操作數(shù)組開頭和結(jié)尾,無法操作中間項(xiàng),如果要操作中間的項(xiàng),使用splice方法

使用splice()方法

這個(gè)方法很強(qiáng)大,可以對(duì)數(shù)組任意項(xiàng)進(jìn)行增加,刪除,替換操作

修改操作:

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

第一個(gè)參數(shù)是準(zhǔn)備操作的數(shù)組位置,第二個(gè)參數(shù)是操作位置后面的數(shù)組項(xiàng)數(shù),第三個(gè)以后的就是,被替換后的內(nèi)容
例子就是表示:從chaomao這個(gè)數(shù)組位置2開始(也就是值為3的那一項(xiàng),數(shù)組下標(biāo)從0開始的),位置2后的一項(xiàng),替換成成8,9
如果把第二個(gè)參數(shù)改為2,也就是chaomao.splice(2,2,8,9),也就是說位置2后面的兩項(xiàng)換成8,9,打印出來的結(jié)果就是1,2,8,9,5,3和4這2兩項(xiàng)被換掉了
這里需要說明的是,被替換的項(xiàng)數(shù)不一定要和替換的項(xiàng)數(shù)相等,1項(xiàng)可以被換成3項(xiàng),5項(xiàng)也可以被換成2項(xiàng),基于這個(gè)原理,我們就用這個(gè)方法來對(duì)數(shù)組進(jìn)行添加和刪除操作

刪除操作:

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

上面例子中,把chaomao中的位置2后的1項(xiàng)替換成空的,因?yàn)楹竺鏇]有內(nèi)容,結(jié)果可以看到,把3這項(xiàng)刪除了

添加操作:

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項(xiàng)換成8,9,也就等于添加了兩項(xiàng)
其實(shí),刪除和添加操作都只是splice修改方法的兩種衍生罷了

鍵值對(duì)結(jié)構(gòu)(對(duì)象)

js中刪除對(duì)象元素用delete操作符
我們來看看一個(gè)例子

代碼如下:
var p ={
"name": “chaomao”,
"age":45,
"sex":"male"
};
delete p.name
for(var i in p){
console.log(i);//輸出age,sex,name項(xiàng)已經(jīng)被刪除了
}

添加json元素的方法

代碼如下:
var json = {}; // 如果json已經(jīng)定義就跳過
json[text] = value;
json.text2 = value2;  // 此時(shí)text2必須符合變量名標(biāo)準(zhǔn),否則得使用數(shù)組方式賦值

javascript里面的數(shù)組,json對(duì)象,動(dòng)態(tài)添加,修改,刪除示例 

<!DOCTYPE html>
<html>
    
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>javascript里面的數(shù)組,json對(duì)象,動(dòng)態(tài)添加,修改,刪除示例</title>
        <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js" rel="external nofollow"  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里面的數(shù)組,json對(duì)象,動(dòng)態(tài)添加,修改,
刪除示例 只要適合Javascript的方法都是可以用在JSON對(duì)象的數(shù)組中的!
所以還有另外的方法splice( )進(jìn)行crud操作!
*/
            //增加屬性
            $(a).attr("id", "1");
            //增加子對(duì)象
            a.data.push(b); //數(shù)組最后加一條記錄
            a.data.push(c);
            a.data.push(d);
            a.data.unshift(d); //數(shù)組最前面加一條記錄
            //修改子對(duì)象及屬性
            a.title = "這是json名字";
            //刪除子對(duì)象
            //json的刪除有很多種,直接用過 delete json對(duì)象方式:
            delete a.data[1];
            a.data.pop(); //刪除最后一項(xiàng)
            a.data.shift(); //刪除第一項(xiàng)
            a.data.splice(0, 1); //刪除指定子對(duì)象,參數(shù):開始位置,刪除個(gè)數(shù)
            //替換不刪除
            a.data.splice(1, 0, e, f); //開始位置,刪除個(gè)數(shù),插入對(duì)象
            //替換并刪除 a.data.splice(0, 1, e, f);//開始位置,刪除個(gè)數(shù),插入對(duì)象
        }
        </script>
    </head>
    
    <body onload="myObjectPush()"></body>

</html>


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)