可能未声明父变量时如何显示一列数据?

问题描述

我正在我的 codeigniter 项目的视图层中生成一些动态内容

<td class="<?PHP echo empty($log->category) ? "noactioncell" :''; ?> text-center align-middle">
<?PHP echo !empty($log->category) ? foreach($log->category as $c):echo $c->category_name."<br/>"; endforeach; : '';?></td>

问题是,我的三元表达式出现以下错误

解析错误:语法错误,意外标记“foreach”

如何在未声明 category_name显示<br/> 标记分隔的循环 $log->category 数据而不产生此错误

解决方法

您发布的代码编码错误。正确且更具可读性的变体将是这样的:

<td class="<?php echo empty($log->category) ? "noactioncell" :''; ?> text-center align-middle">
<?php 
    if(!empty($log->category)){
        foreach($log->category as $c){
            echo $c->category_name."<br/>"; 
        }
    }
?>
</td>

这是一个很好的解释:

三元运算符采用 (expr1) 形式的 3 个表达式? (expr2) : (expr3).

continue(在您的情况下或 foreach)是一个控制结构语句,而不是一个表达式。和 因此,它不能是三元运算符的操作数。事实上,没有 的 PHP 运算符接受控制结构作为操作数,只要 我意识到。这同样适用于其他广泛的 C 系列 语言也是如此。

为了可读性,最好使用 if 在你的情况下声明。

作者@Fabrício Matté How to use continue keyword in a ternary operator in php

,

您当然可以在一行代码中将柱状数据与 <br> 粘合在一起,但我不会使用三元表达式来做到这一点。

由于您的多维对象可能或可能声明了 category 属性,您可以将 empty() 用于第一个条件(三元表达式)。至于要作为<td>文本加入的数据,可以使用空合并运算符回退到数组。如果您要求未声明的列,array_column() 不会抱怨。使用这种技术组合可以防止循环中生成不必要的尾随 </br>。对于这种情况,内爆平面数组是一种更好/更简洁的方法(无论您喜欢哪种语法/风格)。

代码:(Demo)

<td class="<?php echo empty($log->category) ? 'noactioncell ' : ''; ?>text-center align-middle">
    <?php echo implode('<br/>',array_column($log->category ?? [],'category_name')); ?>
</td>

category 有 3 个 category_name 属性时输出:

<td class="text-center align-middle">
    example1<br/>example2<br/>example3
</td>

未声明 category 时的输出:

<td class="noactioncell text-center align-middle">
</td>

太难读了?好的,将其分散到多行中。

<td class="<?php echo empty($log->category) ? 'noactioncell ' : ''; ?>text-center align-middle">
    <?php echo implode(
                   '<br/>',array_column(
                       $log->category ?? [],'category_name'
                   )
                ); ?>
</td>

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...