重新排列数组索引 雄辩的拉拉维尔


Rearrange array index Eloquent Laravel

从 laravel 雄辩数组中删除元素后出现错误

物业有房间

foreach ($property->rooms as $key => $room) {
    if ($room->type == 1 and $type ==1 and $room->price < $price->min or $room->price > $price->max) {
            print_r($property->rooms);
            unset($property->rooms[$key]);
            //$array = array_values($property->rooms); doesn't work
            print_r($property->rooms);
        }
    }

当我将其编码为 json 时,数组将转换为对象而不是数组

取消设置之前

Illuminate'Database'Eloquent'Collection Object
(
[items:protected] => Array
    (
        [0] => Room Object
            (
                [table:protected] => rooms
                [fillable:protected] => Array
                    (
                        [0] => properties_id
                        [1] => price
                        [2] => is_available
                        [3] => type
                        [4] => description
                    )
                [connection:protected] => 
                [primaryKey:protected] => id
                [perPage:protected] => 15
                [incrementing] => 1
                [timestamps] => 1
                [attributes:protected] => Array
                    (
                        [id] => 1
                        [properties_id] => 4
                        [price] => 450000
                        [is_available] => 1
                        [created_at] => 0000-00-00 00:00:00
                        [updated_at] => 2014-10-20 22:27:44
                        [type] => 1
                        [description] => 
                    )
                [original:protected] => Array
                    (
                        [id] => 1
                        [properties_id] => 4
                        [price] => 450000
                        [is_available] => 1
                        [created_at] => 0000-00-00 00:00:00
                        [updated_at] => 2014-10-20 22:27:44
                        [type] => 1
                        [description] => 
                    )
                [relations:protected] => Array
                    (
                    )
                [hidden:protected] => Array
                    (
                    )
                [visible:protected] => Array
                    (
                    )
                [appends:protected] => Array
                    (
                    )
                [guarded:protected] => Array
                    (
                        [0] => *
                    )
                [dates:protected] => Array
                    (
                    )
                [touches:protected] => Array
                    (
                    )
                [observables:protected] => Array
                    (
                    )
                [with:protected] => Array
                    (
                    )
                [morphClass:protected] => 
                [exists] => 1
            )
        [1] => Room Object
            (
                [table:protected] => rooms
                [fillable:protected] => Array
                    (
                        [0] => properties_id
                        [1] => price
                        [2] => is_available
                        [3] => type
                        [4] => description
                    )
                [connection:protected] => 
                [primaryKey:protected] => id
                [perPage:protected] => 15
                [incrementing] => 1
                [timestamps] => 1
                [attributes:protected] => Array
                    (
                        [id] => 2
                        [properties_id] => 4
                        [price] => 350000
                        [is_available] => 1
                        [created_at] => 0000-00-00 00:00:00
                        [updated_at] => 2014-10-21 18:13:15
                        [type] => 1
                        [description] => 
                    )
                [original:protected] => Array
                    (
                        [id] => 2
                        [properties_id] => 4
                        [price] => 350000
                        [is_available] => 1
                        [created_at] => 0000-00-00 00:00:00
                        [updated_at] => 2014-10-21 18:13:15
                        [type] => 1
                        [description] => 
                    )
                [relations:protected] => Array
                    (
                    )
                [hidden:protected] => Array
                    (
                    )
                [visible:protected] => Array
                    (
                    )
                [appends:protected] => Array
                    (
                    )
                [guarded:protected] => Array
                    (
                        [0] => *
                    )
                [dates:protected] => Array
                    (
                    )
                [touches:protected] => Array
                    (
                    )
                [observables:protected] => Array
                    (
                    )
                [with:protected] => Array
                    (
                    )
                [morphClass:protected] => 
                [exists] => 1
            )
        [2] => Room Object
            (
                [table:protected] => rooms
                [fillable:protected] => Array
                    (
                        [0] => properties_id
                        [1] => price
                        [2] => is_available
                        [3] => type
                        [4] => description
                    )
                [connection:protected] => 
                [primaryKey:protected] => id
                [perPage:protected] => 15
                [incrementing] => 1
                [timestamps] => 1
                [attributes:protected] => Array
                    (
                        [id] => 3
                        [properties_id] => 4
                        [price] => 250000
                        [is_available] => 1
                        [created_at] => 0000-00-00 00:00:00
                        [updated_at] => 0000-00-00 00:00:00
                        [type] => 1
                        [description] => 
                    )
                [original:protected] => Array
                    (
                        [id] => 3
                        [properties_id] => 4
                        [price] => 250000
                        [is_available] => 1
                        [created_at] => 0000-00-00 00:00:00
                        [updated_at] => 0000-00-00 00:00:00
                        [type] => 1
                        [description] => 
                    )
                [relations:protected] => Array
                    (
                    )
                [hidden:protected] => Array
                    (
                    )
                [visible:protected] => Array
                    (
                    )
                [appends:protected] => Array
                    (
                    )
                [guarded:protected] => Array
                    (
                        [0] => *
                    )
                [dates:protected] => Array
                    (
                    )
                [touches:protected] => Array
                    (
                    )
                [observables:protected] => Array
                    (
                    )
                [with:protected] => Array
                    (
                    )
                [morphClass:protected] => 
                [exists] => 1
            )
    )

取消设置后

Illuminate'Database'Eloquent'Collection Object
(
[items:protected] => Array
    (
        [1] => Room Object
            (
                [table:protected] => rooms
                [fillable:protected] => Array
                    (
                        [0] => properties_id
                        [1] => price
                        [2] => is_available
                        [3] => type
                        [4] => description
                    )
                [connection:protected] => 
                [primaryKey:protected] => id
                [perPage:protected] => 15
                [incrementing] => 1
                [timestamps] => 1
                [attributes:protected] => Array
                    (
                        [id] => 2
                        [properties_id] => 4
                        [price] => 350000
                        [is_available] => 1
                        [created_at] => 0000-00-00 00:00:00
                        [updated_at] => 2014-10-21 18:13:15
                        [type] => 1
                        [description] => 
                    )
                [original:protected] => Array
                    (
                        [id] => 2
                        [properties_id] => 4
                        [price] => 350000
                        [is_available] => 1
                        [created_at] => 0000-00-00 00:00:00
                        [updated_at] => 2014-10-21 18:13:15
                        [type] => 1
                        [description] => 
                    )
                [relations:protected] => Array
                    (
                    )
                [hidden:protected] => Array
                    (
                    )
                [visible:protected] => Array
                    (
                    )
                [appends:protected] => Array
                    (
                    )
                [guarded:protected] => Array
                    (
                        [0] => *
                    )
                [dates:protected] => Array
                    (
                    )
                [touches:protected] => Array
                    (
                    )
                [observables:protected] => Array
                    (
                    )
                [with:protected] => Array
                    (
                    )
                [morphClass:protected] => 
                [exists] => 1
            )
        [2] => Room Object
            (
                [table:protected] => rooms
                [fillable:protected] => Array
                    (
                        [0] => properties_id
                        [1] => price
                        [2] => is_available
                        [3] => type
                        [4] => description
                    )
                [connection:protected] => 
                [primaryKey:protected] => id
                [perPage:protected] => 15
                [incrementing] => 1
                [timestamps] => 1
                [attributes:protected] => Array
                    (
                        [id] => 3
                        [properties_id] => 4
                        [price] => 250000
                        [is_available] => 1
                        [created_at] => 0000-00-00 00:00:00
                        [updated_at] => 0000-00-00 00:00:00
                        [type] => 1
                        [description] => 
                    )
                [original:protected] => Array
                    (
                        [id] => 3
                        [properties_id] => 4
                        [price] => 250000
                        [is_available] => 1
                        [created_at] => 0000-00-00 00:00:00
                        [updated_at] => 0000-00-00 00:00:00
                        [type] => 1
                        [description] => 
                    )
                [relations:protected] => Array
                    (
                    )
                [hidden:protected] => Array
                    (
                    )
                [visible:protected] => Array
                    (
                    )
                [appends:protected] => Array
                    (
                    )
                [guarded:protected] => Array
                    (
                        [0] => *
                    )
                [dates:protected] => Array
                    (
                    )
                [touches:protected] => Array
                    (
                    )
                [observables:protected] => Array
                    (
                    )
                [with:protected] => Array
                    (
                    )
                [morphClass:protected] => 
                [exists] => 1
            )
    )

转换为 JSON 房间字段应该是数组而不是对象:

{"other_parameters": "something","rooms":{"1":{"id":2,"properties_id":4,"price":350000,"is_available":1,"created_at":"-0001-11-30 00:00:00","updated_at":"2014-10-21 18:13:15","type":1,"description":null},"2":{"id":3,"properties_id":4,"price":250000,"is_available":1,"created_at":"-0001-11-30 00:00:00","updated_at":"-0001-11-30 00:00:00","type":1,"description":""}}}

我在 laravel 文档中找到了解决方案。

修改数组后,您必须从 Laravel 集合中调用一个名为 values() 的方法来排列数组索引,例如:

unset($property->rooms[$key]);
$property->rooms->values();

选项 1

$array = array();
foreach ($property->rooms as $key => $room) {
    if ($room->type == 1) {
        unset($property->rooms->{$key}); <<-- pay attention to this
    } else {
        $array[] = get_object_vars($room); // sort the passed row into new array
    }
}
print_r($array);

选项 2

要从 JSON 转换为数组,请将 assoc 标志设置为 TRUE:

json_decode('Your json script', true);
foreach ($property['rooms'] as $key => $room) {
    if ($room['type'] == 1) {
        unset($property['rooms'][$key]);
    }
}
$array = array_values($property['rooms']); 
print_r($array);