unset 数组 json_encode 数据格式

今天 遇到了个很有趣的问题 

$arr = array(array(1,23),array(1,23),array(1,23));

var_dump($arr);
print_r(json_encode($arr));
echo '<br/>';
foreach($arr as $k=>$v)
{
	if ($k == 1)
	{
		unset($arr[$k]);
	}
}

var_dump($arr);
print_r(json_encode($arr));die;

这段代码执行完后的结果是



可以看到 unset后 在json_encode数据格式变了,研究了下, 大概是因为数组 被从中间去掉了个元素 为了保证数组的元素顺序被加上了数字key这样,以确认去掉了一个元素 二不使key发生变化可以看 绿色部分, 那么 怎么解决呢 只需一行代码搞定

在foreach之后加

$arr = array_values($arr);

将数组重新索引了下 就好了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这段代码是一个条件判断的逻辑块,其目的是根据特定条件对变量进行处理。以下是代码的解释: - 首先,判断变量`$filter`是否非空(`!empty($filter)`)。 - 如果`$filter`非空,则将其解码为关联数组,并赋值给`$filter`变量:`$filter = json_decode($filter, true);`。 - 同样地,将变量`$op`解码为关联数组,并赋值给`$op`变量:`$op = json_decode($op, true);`。 - 在接下来的条件判断中,检查是否存在键名为`'gongcheng.zhuanye.name'`的元素: - 如果存在,则执行以下操作: - 通过查询数据库表`zhuanye`,根据给定的条件获取满足条件的记录的`id`字段值,并将这些值以数组形式赋值给`$zhuanyeIds`变量。 - 使用`$zhuanyeIds`作为条件,查询数据库表`gongcheng`,获取满足条件的记录的`id`字段值,并将这些值以数组形式赋值给`$gongchengID`变量。 - 使用逗号将`$gongchengID`数组中的元素连接起来,并将结果以字符串形式赋值给`$gongchengID`变量。 - 移除关联数组中的特定键名和对应值:`unset($filter['gongcheng.zhuanye.name'], $op['gongcheng.zhuanye.name']);`。 - 将修改后的`$gongchengID`赋值给`$filter['gongcheng.id']`。 - 将字符串`"in"`赋值给`$op['gongcheng.id']`。 - 通过修改请求参数,更新`filter`和`op`的值:`$this->request->get(['filter'=>json_encode($filter)]);`和`$this->request->get(['op'=>json_encode($op)]);`。 总体而言,这段代码的目的是根据特定条件对`$filter`和`$op`进行处理,并更新请求参数。请注意,代码中还存在其他未提及的逻辑和变量,因此上述解释可能不是完整的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值