[英]Looping through 2 different arrays to check if a value exists
好吧,我有這個包含3個對象數組的數組,所以它看起來像
$invoice
$invoice->foo
$invoice->foo->bars
$invoice->bars
$invoice->foobars
我在表格中顯示了所有的foo條
<?php foreach($invoice->foo->bars as $bar) { ?>
<tr>
<td>
<?php echo $bar->some_field;
</td>
<td>
<?php echo $bar->another_field;
</td>
</tr>
我有一個下拉按鈕,看起來像
<ul>
<li><a href="some_url/edit/$bar->id">edit</a></li>
<li><a href="some_url/delete/$bar->id">Delete</a></li>
<li><a href="some_url/add_foobar/$bar->id">Add foobar</a></li>
</ul>
我現在是否正在通過這樣做檢查酒吧是否有foobar
for ($i=0; $i < count($invoice->foobars); $i++) {
$foobar_bars[] = $invoice->foobars[$i]->foobar_bar_id;
}
在$ invoice-> foo-> bars循環中,我檢查以顯示類似的按鈕
<ul>
<li><a href="some_url/edit/$bar->id">edit</a></li>
<li><a href="some_url/delete/$bar->id">Delete</a></li>
<?php if(!in_array($bar->dd_id, $companion_bars)){ ?>
<li><a href="some_url/add_foobar/$bar->id">Add Foobar</a></li>
<?php } ?>
</ul>
我想知道這是最有效的方法還是他們檢查酒吧是否有foobar的更好方法
我認為最有效的方法是實際擁有一個告訴您是否存在這種情況的方法:
if ($bar->hasCompanionBar()) {
// the condition is TRUE
}
這樣一來,您可以將最有效的決定推遲到以后。 這樣一來,您就可以在代碼庫的整個生命周期內創建最高效的代碼。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.