
本文讲解如何正确使用 php 的 foreach 循环遍历多维数组,将每篇文章的 title、description 和 link 动态插入 html 模板中,避免重复输出静态变量的问题。
在 PHP 中,若想为数组中的每一项生成独立的 HTML 结构(如卡片式文章展示),关键在于:不能预先拼接含固定变量的字符串模板,而应在循环体内实时提取当前项的数据并插入对应位置。
你当前代码的问题在于:
- $str 是在循环外定义的,其中的 $title 是一个固定字符串('Paragraph of text'),与 $articles 数组无关;
- foreach 中仅重复 echo $str,自然每次都输出相同内容;
- 错误地写了 $var['title'](应为 $v['title']),且未在循环内更新 $str 或直接内联输出。
✅ 正确做法是:在 foreach 循环内部,针对每个 $v(即当前文章数组)提取其字段,并直接嵌入 HTML 输出中。推荐使用“内联输出”方式,清晰、安全、易维护:
<?php
$articles = [
[
"title" => "Featured title 1",
"description" => "Paragraph of text beneath the heading to explain the heading. We'll add onto it with another sentence and probably just keep going until we run out of words.",
"link" => "page1.php",
],
[
"title" => "Featured title 2",
"description" => "Another compelling summary with key details.",
"link" => "page2.php",
],
[
"title" => "Featured title 3",
"description" => "A concise yet informative description for the third feature.",
"link" => "page3.php",
],
];
// 使用 foreach 动态渲染每张卡片
foreach ($articles as $article) {
echo '<div class="feature col">';
echo ' <div class="feature-icon bg-primary bg-gradient">';
echo ' <svg class="bi" width="1em" height="1em"><use xlink:href="#collection"></use></svg>';
echo ' </div>';
echo ' <h2>' . htmlspecialchars($article['title']) . '</h2>';
echo ' <p>' . htmlspecialchars($article['description']) . '</p><div class="aritcle_card flexRow">
<div class="artcardd flexRow">
<a class="aritcle_card_img" href="/ai/761" title="Pliny"><img
src="https://img.php.cn/upload/ai_manual/001/503/042/68b6db26747b8162.png" alt="Pliny" onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
<div class="aritcle_card_info flexColumn">
<a href="/ai/761" title="Pliny">Pliny</a>
<p>创建、分享和重新组合AI应用程序</p>
</div>
<a href="/ai/761" title="Pliny" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
</div>
</div><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/7fc7563c4182" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">PHP免费学习笔记(深入)</a>”;</p>';
echo ' <a href="' . htmlspecialchars($article['link']) . '" class="icon-link">';
echo ' Call to action';
echo ' <svg class="bi" width="1em" height="1em"><use xlink:href="#chevron-right"></use></svg>';
echo ' </a>';
echo '</div>';
}
?>? 关键要点说明:
- ✅ 使用 $article['title'] 等语法从当前循环项中取值,确保每次输出真实数据;
- ✅ 推荐直接 echo HTML 片段(而非拼接大字符串),提升可读性与调试效率;
- ✅ 务必对输出到 HTML 的变量使用 htmlspecialchars() 进行转义,防止 XSS 漏洞(尤其当内容来自用户或不可信来源时);
- ❌ 避免在循环外构建含变量的 $str 字符串——PHP 不支持模板字符串自动绑定,变量不会“动态重解析”。
? 扩展建议:若结构复杂或需复用,可封装为函数或采用 sprintf() / 输出缓冲(ob_start())等更工程化方式,但对三张卡片这类简单场景,内联 foreach + echo 是最直观、可靠的选择。










