关于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;
相关推荐
草莓熊Lotso13 分钟前
【C++】--函数参数传递:传值与传引用的深度解析
c语言·开发语言·c++·其他·算法
Ice__Cai19 分钟前
Flask 路由详解:构建灵活的 URL 映射系统
开发语言·python·flask
l1t1 小时前
分析xml标签属性和压缩级别对xlsx文件读取解析的影响
xml·开发语言·python·sql·duckdb
Jenkinscao1 小时前
我从零开始学习C语言(13)- 循环语句 PART2
c语言·开发语言·学习
王伯爵1 小时前
go语言中的select的用法和使用场景
开发语言·数据库·golang
Chandler_Song2 小时前
【Python代码】谷歌专利CSV处理函数
开发语言·python·pandas
我是一只菜菜2 小时前
中国大学MOOC--C语言第十一周结构类型
c语言·开发语言
源代码•宸3 小时前
网络流量分析——基础知识(二)(Tcpdump 基础知识)
运维·开发语言·网络·c++·经验分享·tcpdump
fs哆哆10 小时前
在VB.net中一维数组,与VBA有什么区别
java·开发语言·数据结构·算法·.net
johnZhangqi10 小时前
深圳大学-计算机信息管理课程实验 C++ 自考模拟题
java·开发语言·c++