laravel - 嵌套 foreach 循环以显示数据
问题描述
我有 5 个模型Purchase
、Inventory
、Slab
和。我从模型中获取集合,然后从该集合中获取表中的数据。然后根据该数据,我将进一步建模与. 现在,在从模型中获取数据后,我想使用循环在刀片上显示它。但我收到错误:Scarting
FloorTile
Purchase
Inventory
Slab
Inventory
Slab
Foreach
为 foreach() 提供的参数无效
我已经在我的控制器中尝试过这个:
$slabs = Purchase::where('factoryName', $factoryName)->with('inventory.slab')->get();
该查询结果如下:
{
"id": 36,
"marbleType_id": 2,
"fname": "Sama",
"lname": "Jojo",
"factoryName": "Sama Inc.",
"cnic": "3216542",
"area": "Johar town",
"city": "Lahore",
"province": "Punjab",
"phone1": "45678912345",
"phone2": "45678912345",
"inventory_ID": 10,
"created_at": "2019-03-19 12:11:45",
"updated_at": "2019-03-19 12:11:45",
"inventory": {
"id": 10,
"purchase_id": 36,
"marbleType": "1",
"totalSquareFt": 25,
"priceperSquareFt": 230,
"totalPurchasePrice": 25000,
"standardSize_ID": "5",
"salePrice": 250,
"miliMeter": "6mm",
"slab_ID": 1,
"scarting_ID": null,
"floorTile_ID": null,
"created_at": "2019-03-19 12:11:45",
"updated_at": "2019-03-19 12:11:45",
"slab": {
"id": 1,
"marbleName_ID": "2",
"inventory_ID": "10",
"created_at": "2019-03-19 12:11:45",
"updated_at": "2019-03-19 12:11:45"
}
}
},
{
"id": 55,
"marbleType_id": 3,
"fname": "Sama",
"lname": "Jojo",
"factoryName": "Sama Inc.",
"cnic": "32165421",
"area": "Johar town",
"city": "Lahore",
"province": "Punjab",
"phone1": "45678912345",
"phone2": "45678912345",
"inventory_ID": 26,
"created_at": "2019-04-25 10:47:41",
"updated_at": "2019-04-25 10:47:41",
"inventory": {
"id": 26,
"purchase_id": 55,
"marbleType": "1",
"totalSquareFt": 12,
"priceperSquareFt": 12,
"totalPurchasePrice": 120,
"standardSize_ID": "1",
"salePrice": 15,
"miliMeter": "6mm",
"slab_ID": 9,
"scarting_ID": null,
"floorTile_ID": null,
"created_at": "2019-04-25 10:47:41",
"updated_at": "2019-04-25 10:47:41",
"slab": {
"id": 9,
"marbleName_ID": "3",
"inventory_ID": "26",
"created_at": "2019-04-25 10:47:41",
"updated_at": "2019-04-25 10:47:41"
}
}
},
{
"id": 56,
"marbleType_id": 4,
"fname": "Sama",
"lname": "Jojo",
"factoryName": "Sama Inc.",
"cnic": null,
"area": "Johar town",
"city": "Lahore",
"province": "Punjab",
"phone1": "45678912345",
"phone2": "45678912345",
"inventory_ID": 27,
"created_at": "2019-05-05 20:11:52",
"updated_at": "2019-05-05 20:11:52",
"inventory": {
"id": 27,
"purchase_id": 56,
"marbleType": "3",
"totalSquareFt": 20,
"priceperSquareFt": 20,
"totalPurchasePrice": 420,
"standardSize_ID": "3",
"salePrice": 25,
"miliMeter": "6mm",
"slab_ID": null,
"scarting_ID": null,
"floorTile_ID": 10,
"created_at": "2019-05-05 20:11:52",
"updated_at": "2019-05-05 20:11:52",
"slab": null
}
},
{
"id": 57,
"marbleType_id": 9,
"fname": "Sama",
"lname": "Jojo",
"factoryName": "Sama Inc.",
"cnic": null,
"area": "Johar town",
"city": "Lahore",
"province": "Punjab",
"phone1": "45678912345",
"phone2": "45678912345",
"inventory_ID": 28,
"created_at": "2019-05-05 20:32:41",
"updated_at": "2019-05-05 20:32:41",
"inventory": {
"id": 28,
"purchase_id": 57,
"marbleType": "2",
"totalSquareFt": 31,
"priceperSquareFt": 12,
"totalPurchasePrice": 400,
"standardSize_ID": "1",
"salePrice": 15,
"miliMeter": "8mm",
"slab_ID": null,
"scarting_ID": 4,
"floorTile_ID": null,
"created_at": "2019-05-05 20:32:41",
"updated_at": "2019-05-05 20:32:42",
"slab": null
}
},
{
"id": 59,
"marbleType_id": 12,
"fname": "Sama",
"lname": "Jojo",
"factoryName": "Sama Inc.",
"cnic": null,
"area": "Johar town",
"city": "Lahore",
"province": "Punjab",
"phone1": "12345678945",
"phone2": "45678945645",
"inventory_ID": 30,
"created_at": "2019-05-06 10:14:35",
"updated_at": "2019-05-06 10:14:35",
"inventory": {
"id": 30,
"purchase_id": 59,
"marbleType": "2",
"totalSquareFt": 12,
"priceperSquareFt": 12,
"totalPurchasePrice": 122,
"standardSize_ID": "1",
"salePrice": 12,
"miliMeter": "8mm",
"slab_ID": null,
"scarting_ID": 5,
"floorTile_ID": null,
"created_at": "2019-05-06 10:14:35",
"updated_at": "2019-05-06 10:14:35",
"slab": null
}
}
这是控制器中的 Foreach 循环,用于获取仅与Slab
.
foreach ($slabs as $slab) {
if ($slab->inventory->slab_ID != NULL) {
$marble_id = $slab->inventory->slab->marbleName_ID;
$slab->marble = MarbleType::where('id', $marble_id)->get();
}
}
这是我想Slab
在表格中显示数据的刀片内容。
@foreach($slabs as $slab)
@foreach($slab->marble as $mar)
<tr>
@if($slab->inventory->marbleType == 1)
<td> Slab </td>
@endif
<td>{{ $mar->marbleType }}</td>
<td>{{ $slab->inventory->totalSquareFt }}</td>
<td>{{ $slab->inventory->totalPurchasePrice }}</td>
<td>{{ date('M j, Y h:ia' , strtotime( $slab->created_at )) }}</td>
</tr>
@endforeach
@endforeach
这是我在刀片文件上遇到的错误:
Invalid argument supplied for foreach()
谁能指出我做错了什么。?
解决方案
您可能需要else
在支票上声明$slab->inventory->slab_ID
,否则,您将尝试循环null
($slab->marble
将等同于null
)。如果你这样做了else { $slab->marble = []; }
,那么你就可以使用它foreach
而无需担心代码。
foreach ($slabs as $slab) {
if ($slab->inventory->slab_ID != NULL) {
$marble_id = $slab->inventory->slab->marbleName_ID;
$slab->marble = MarbleType::where('id', $marble_id)->get();
} else {
$slab->marble = [];
}
foreach($slab->marble AS $mar){
...
}
}
旁注,此代码可能非常低效。每当您需要在循环中运行查询时,您都可能面临瓶颈。考虑在初始查询中使用关系并预先加载它。
另请注意,如果$slab->inventory
是null
,您在使用时会遇到trying to get property of non-object
错误$slab->inventory->slab_ID
。
推荐阅读
- firebase - 配置来自客户端的 Firebase 最大请求 (FirebaseTooManyRequestsException)
- c# - 在实体框架中有两个代表同一个表的类?
- cmake - SET(CPACK_COMPONENTS_ALL ...) 与 ExternalProject 安装附加组件
- php - 我如何替换 {code} 或 {noformat} Wikitext
tags
- tcl - 如何使用 Critcl 字节数组?
- jquery - 如何根据在列表视图中选中或未选中的复选框隐藏更改的下拉列表?
- c# - Autofac 如何帮助您同时在现有类中注入类/接口的多个实例
- sql-server - How to add row in SQL if value from one column is greater than the value in another column
- angular - 使用角度从数据库返回信息
- java - ImageIO 写具体的 tiff