本文介绍如何在 php 动态拼接的 html 字符串中,为条件判断生成的文字(如 "unable" 和 "used")分别应用红色和绿色样式,通过内联 css 实现即时、可靠的前端着色效果。
在 PHP 中输出带样式的文本(如变色文字),本质是向浏览器输出合法的 HTML + CSS 内容。由于 PHP 本身不直接渲染颜色,需借助 HTML 标签(如 )包裹文本,并通过 style 属性注入 CSS 样式。
以你的原始代码为例:
$paragrap .= $used->NAME." - ".(empty($used->is_complete) ? 'Unable' : 'Used')." - ".$helper->timeLeft($used->created)."
";
其中 'Unable' 和 'Used' 是纯文本,浏览器会按默认颜色(通常是黑色)显示。要实现颜色区分,只需将它们替换为带内联样式的 HTML 片段:
✅ 正确写法(推荐):
$paragrap .= $used->NAME." - "
. (empty($used->is_complete)
? 'Unable'
: 'Used')
. " - " . $helper->timeLeft($used->created) . "
";? 小贴士:
? 'Unable' : 'Used'
并在 CSS 中统一定义:
.status-pending { color: #d32f2f; } /* 深红色 */
.status-completed { color: #2e7d32; } /* 深绿色 */⚠️ 注意事项:
ess CSS 变量),提升可访问性与兼容性。总结:PHP 控制逻辑,HTML/CSS 负责呈现。一次精准的 封装 + 内联样式,即可干净、高效地实现条件化文本着色——简洁、可靠,无需额外依赖。