关于PHP中删除JSON指定元素unset和array_splice的区别

  1. unset(mixed var, mixed ...vars): void

unset 不会改变原有索引顺序


  1. array_splice(

array &$array,

int $offset,

?int $length = null,

mixed $replacement = []

): array

array_splice 删除后,会重新排序索引顺序


假设有以下JSON数据

javascript 复制代码
{"dataRows": [{"id": 1,"val": "a"},{"id": 2,"val": "b"},{"id":3,"val": "c"}]}

一、unset 方法删除只能删除最后一个元素,否则JSON数据格式将会被改变。例如:

  1. 仅删除第1个元素,或第2个元素,但不能是末尾的元素。
php 复制代码
 foreach ($dataRows as $i => $row) {
        if ($row['id'] == 1) {
            unset($dataRows[$i]); // 删除了 {"id": 1,"val": "a"}
        }
    }

结果:{"dataRows": {"0":{"id": 2,"val": "b"},"1":{"id":3,"val": "c"}}}

或者:{"dataRows": {"0":{"id": 1,"val": "a"},"1":{"id":3,"val": "c"}}}

注意,数组中的方括号"dataRows":[...]变成了花括号"dataRows":{...},程序给每行元素前自动增加了一个索引号。

  1. 仅删除最后一个元素
php 复制代码
 foreach ($dataRows as $i => $row) {
        if ($row['id'] == 2) {
            unset($dataRows[$i]);
        }
    }

结果:{"dataRows": [{"id": 1,"val": "a"},{"id": 2,"val": "b"}]}

注意,数组中的方括号"dataRows":[...]没有改变


二、array_splice 方法可以删除任意行元素,JSON数据格式都不会被改变。例如:

php 复制代码
 foreach ($dataRows as $i => $row) {
        if ($row['id'] == 1) {
            array_splice($dataRows, $i, 1);
        }
    }

结果:{"dataRows": [{"id": 2,"val": "b"},{"id":3,"val": "c"}]}
注意,数组中的方括号"dataRows":[...]没有改变


总结:为了保证JSON数据格式统一,尽量使用 array_splice 方法删除JSON元素。

当JSON数组中的方括号"dataRows":[...]变成了花括号"dataRows":{...}后,获取记录集总数需要用:Object.keys(dataRows).length,否则返回 undefined。

为了兼容不同JSON数据格式,使用如下语句即可:

php 复制代码
var recordCount = dataRows.length || Object.keys(dataRows).length;
相关推荐
Y1rong3 小时前
C++ QT之记事本
开发语言·qt
diegoXie6 小时前
Python / R 向量顺序分割与跨步分割
开发语言·python·r语言
程序员小白条6 小时前
0经验如何找实习?
java·开发语言·数据结构·数据库·链表
liulilittle7 小时前
C++ 浮点数封装。
linux·服务器·开发语言·前端·网络·数据库·c++
失散137 小时前
Python——1 概述
开发语言·python
萧鼎7 小时前
Python 图像哈希库 imagehash——从原理到实践
开发语言·python·哈希算法
小小8程序员8 小时前
STL 库(C++ Standard Template Library)全面介绍
java·开发语言·c++
立志成为大牛的小牛8 小时前
数据结构——五十六、排序的基本概念(王道408)
开发语言·数据结构·程序人生·算法
老王熬夜敲代码8 小时前
C++中的atomic
开发语言·c++·笔记·面试
长安即是故里8 小时前
超快的 JSON可视化与处理工具
json·工具