trim() 是最常用也最安全的去首尾空格方式,默认处理 ascii 空格及常见控制字符,不处理中间空格或中文全角空格;需 unicode 支持时推荐 preg_replace('/^[[:space:]]+|[[:space:]]+$/u', '', $str)。

trim() 是最常用也最安全的去首尾空格方式
PHP 里删字符串首尾空格,trim() 就是标准答案。它默认处理 ASCII 空格、制表符、换行符、回车符、垂直制表符和空字符(\0),覆盖绝大多数真实场景。
常见错误是误以为 trim() 会删中间空格——它不会,只动头尾;还有人用 str_replace(' ', '', $str) 想“一锅端”,结果把所有空格(包括有意义的分隔)全干掉了。
-
trim($str):默认行为,够用 -
trim($str, " \t\n\r\0\x0B"):显式指定字符集,便于理解或微调 - 如果字符串含中文全角空格(
),trim()默认不处理,得手动加:trim($str, " \t\n\r\0\x0B\u{3000}")(PHP 7.2+ 支持 Unicode 转义)
ltrim() 和 rtrim() 用于单侧清理
需要只去开头或只去结尾?别硬套 trim() 再补逻辑,直接用 ltrim() 或 rtrim()。它们参数规则和 trim() 完全一致,只是作用范围更精确。
典型使用场景:路径拼接前清理目录末尾斜杠,或处理用户输入时保留末尾缩进语义(比如代码块前导空格)。
立即学习“PHP免费学习笔记(深入)”;
-
ltrim($path, '/'):清理路径开头的多余/,避免//api类错误 -
rtrim($str, "\n\r"):只去换行,保留末尾空格——比如处理 shell 命令输出时很实用 - 注意:它们对多字节字符(如 UTF-8 中文)同样有效,但不自动识别 Unicode 空格类,全角空格仍需手动指定
preg_replace('/^[[:space:]]+|[[:space:]]+$/u', '', $str) 处理 Unicode 空格更彻底
当你的数据来自富文本、移动端输入或国际化环境,很可能混入 Unicode 空格字符(如 \u{2000}~\u{200F}、\u{2028}、\u{2029} 等)。这时 trim() 的默认字符集就不够用了。
正则方案更通用,[[:space:]] 是 POSIX 字符类,在 PHP 中能匹配所有 Unicode 空格字符(需 u 修饰符),比手列字符靠谱。
- 性能略低于
trim(),但差异在微秒级,一般业务无感 - 不要写成
/^\s+|\s+$/u——\s在 PCRE 中默认不包含所有 Unicode 空格,[[:space:]]更稳妥 - 如果只需兼容常见空格且不想引正则,可组合:
trim(trim($str, "\u{3000}"), "\u{2000}\u{2001}..."),但维护成本高
mb_trim() 不存在,别搜了
PHP 没有内置 mb_trim() 函数。网上有些封装是用 mb_substr() 配合循环找边界,既慢又容易出错(比如没考虑组合字符、零宽空格等)。别自己造轮子。
真正需要多字节安全的首尾清理,优先走 preg_replace() 方案;若项目已用 mbstring 扩展且确定字符集(如纯 GBK),可用 mb_ereg_replace('^[\s]+|[\s]+$', '', $str),但兼容性和可读性不如 [[:space:]] 正则。
- 所有 mb_* 字符串函数都不处理“空格语义”,只按字节/码点截取,无法替代空格逻辑判断
- 第三方库如
symfony/string提供了trim()的 Unicode 版本,但引入依赖要权衡
实际用的时候,先问自己:数据来源是否可能含全角或 Unicode 空格?如果是,正则方案虽然多敲几个字,但一次写对,后面省心。否则,trim() 足够干净利落。











