首先要搞清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这一项,因为它是对象的一项,所以我们要用对象的删除方法进行操作

  • 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元素

javascript删除JSON元素的更多相关文章

  1. 【JSON】JavaScript删除json元素

    1.json中的两种结构:对象{}和数组[] 2.直接delete json对象[元素名称].

  2. Javascript 删除tr 元素

    Javascript 删除tr 元素   function delete1(obj){ var tr=obj.parentNode.parentNode; var tbody=tr.parentNod ...

  3. javascript删除数组元素的7个方法

    在JavaScript中,除了Object之外,Array类型(数组)恐怕就是最常用的类型了.与其他语言的数组相比,JavaScript中的Array非常灵活.这种灵活性有利有弊,好处是其富有创造性, ...

  4. JSON相关知识,转载:删除JSON中数组删除操作

    一:JSON是什么 JSONg格式:对象是一个无序的“名称/值”对的集合. 对象以括号开始,括号结束. 名称冒号分隔值. "名称/值"之间用逗号分隔 例: var people = ...

  5. 用Javascript动态添加删除HTML元素实例 (转载)

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. 在Javascript操作JSON对象,增加 删除 修改

    在Javascript操作JSON对象,增加删除修改全有的,详情见代码 <script type="text/javascript"> var jsonObj2 = { ...

  7. javascript 常见数组操作( 1、数组整体元素修改 2、 数组筛选 3、jquery 元素转数组 4、获取两个数组中相同部分或者不同部分 5、数组去重并倒序排序 6、数组排序 7、数组截取slice 8、数组插入、删除splice(需明确位置) 9、数组遍历 10、jQuery根据元素值删除数组元素的方)

    主要内容: 1.数组整体元素修改 2. 数组筛选 3.jquery 元素转数组 4.获取两个数组中相同部分或者不同部分 5.数组去重并倒序排序 6.数组排序 7.数组截取slice 8.数组插入.删除 ...

  8. JS中彻底删除json对象组成的数组中的元素

    只是分享一个小知识~ 在JS中,对于某个由json对象组成的数组,例如: var test = [{ "a": "1", "b": &quo ...

  9. Javascript根据指定下标或对象删除数组元素

    删除数组元素在工作中经常会用到,本文讲解一下Javascript根据下标删除数组元素的方法,需要了解的朋友可以参考下 将一下代码放在全局js文件中: Js代码 /** *删除数组指定下标或指定对象 * ...

随机推荐

  1. 巨蟒python全栈开发linux之cento9

    1.docker入门学习 查看机器中已经启动的所有的进程. ps -ef 2.docker常用命令学习 3.docker学习3 4.dockerfile与镜像 5.docker私有仓库 6.rabbi ...

  2. django的ORM中的2个易混点

    1.django数据模型中null=True和blank=True的区别 null 是针对数据库而言,如果 null=True, 表示数据库的该字段可以为空,即在Null字段显示为YES. blank ...

  3. 修改已生成项目app名称

    在搜索里添加product Name,然后修改成你需要的app名称 修改完后可能会报错误如下 原因是test的测试路径发生了变化,其实如果不修改Test host的路径保留原来的重命名之前的app也是 ...

  4. LR回放https协议脚本失败:[GENERAL_MSG_CAT_SSL_ERROR]connect to host "XXX" failed:[10054] Connection reset by peer [MsgId:MERR-27780]

    最近做一个负载均衡项目的性能测试,使用LR录制脚本协议为https协议,回放脚本时出现报错: [GENERAL_MSG_CAT_SSL_ERROR]connect to host "XXX& ...

  5. Nuxt取消默认的eslint语法检测

    Nuxt项目里自带的有eslint语法检测,这个对开发时候的不规范都会报错,对我们开发有很大帮助,如果我们开发时不想使用这个功能,我们可以取消掉eslint 一.如果整个项目完全不用eslint的话, ...

  6. ActiveMQ 核心概念

    1.Failover 当A无法为客户服务时,系统能够自动地切换,使B能够及时地顶上继续为客户提供服务,且客户感觉不到这个为他提供服务的对象已经更换. 如数据库.应用服务.硬件设备等的失效转移. 2.S ...

  7. python cookbook第三版学习笔记二十:可自定义属性的装饰器

    在开始本节之前,首先介绍下偏函数partial.首先借助help来看下partial的定义 首先来说下第一行解释的意思: partial 一共有三个部分: (1)第一部分也就是第一个参数,是一个函数, ...

  8. (4.8)SQL Server DAC——专用管理员连接

    SQL Server DAC——专用管理员连接 默认情况下,只有本地可以使用DAC连接,但也可以开启远程DAC sp_configure ; go reconfigure with override; ...

  9. 理解java注解

    @是java注解,即annotation. 注解功能可以理解为插件,是代码级别的插件,在类的方法上写:@XXX,就是在代码上插入了一个插件. Java注解是附加在代码中的一些元信息,用于一些工具在编译 ...

  10. C# 学习黑马.Net视频教程,大文件拷贝

    设计器代码: namespace 大文件拷贝 { partial class Form1 { /// <summary> /// 必需的设计器变量. /// </summary> ...