
本文介绍如何使用 php 对指定 div 内的歌词文本按换行符分割,并在每一行末尾(`
` 前)动态插入递增序号,实现类似“第1行、第2行…”的排版效果。
在网页开发中,有时需要对纯文本内容(如歌词、诗歌或用户提交的多行输入)进行结构化编号,但
标签本身不具备语义性,无法像
- 或
那样通过 CSS ::before 或计数器(counter-increment)直接实现行号渲染。因此,必须借助服务端逻辑完成预处理。
推荐使用 PHP 的 explode() 函数,以系统换行符 PHP_EOL 为分隔符将完整歌词字符串拆分为数组,再遍历并拼接序号。注意:实际 HTML 中的
往往由 \n、\r\n 或用户粘贴行为生成,因此需统一归一化换行符,避免因换行符不一致导致分割失败。
✅ 正确示例代码如下:
<?php
// 假设 $lyrics 是从数据库或表单获取的原始歌词字符串
$lyrics = "Every time when I look in the mirror\nAll these lines on my face getting clearer\nThe past is gone\nAnd it went by, like dusk to dawn\nIsn't that the way?\nEverybody's got their dues in life to pay\nYeah, I know nobody knows\nWhere it comes and where it goes\nI know it's everybody's sin\nYou got to lose to know how to win";
// 统一替换 Windows/Linux/Mac 换行符为 PHP_EOL,确保跨平台兼容
$lyrics = str_replace(["\r\n", "\r"], "\n", $lyrics);
$arr = explode("\n", trim($lyrics));
// 输出带序号的每一行(序号从 1 开始)
foreach ($arr as $index => $line) {
if (trim($line) !== '') { // 跳过空行,避免输出 "10<br>" 后跟 "11<br>" 的错位
echo htmlspecialchars($line) . ' ' . ($index + 1) . '<br>';
}
}
?>? 关键注意事项:










