通过使用字包功能。它将文本分割成多行,以便最大宽度是您指定的宽度,在单词边界处断开。拆分后,只需使用第一行:substr($string, 0, strpos(wordwrap($string, $your_desired_width), "\n"));
当文本本身短于所需的宽度时,这个单线没有处理的一件事是这样的。要处理这个边缘情况,我们应该做如下的事情:if (strlen($string) > $your_desired_width) {
$string = wordwrap($string, $your_desired_width);
$string = substr($string, 0, strpos($string, "\n"));}
如果文本包含实际切点之前的换行符,则上述解决方案存在过早裁剪文本的问题。这里有一个解决这个问题的版本:function tokenTruncate($string, $your_desired_width) {
$parts = preg_split('/([\s\n\r]+)/', $string, null, PREG_SPLIT_DELIM_CAPTURE);
$parts_count = count($parts);
$length = 0;
$last_part = 0;
for (; $last_part
$length += strlen($parts[$last_part]);
if ($length > $your_desired_width) { break; }
}
return implode(array_slice($parts, 0, $last_part));}
另外,下面是用于测试实现的PHPUnit测试类:class TokenTruncateTest extends PHPUnit_Framework_TestCase {
public function testBasic() {
$this->assertEquals("1 3 5 7 9 ",
tokenTruncate("1 3 5 7 9 11 14", 10));
}
public function testEmptyString() {
$this->assertEquals("",
tokenTruncate("", 10));
}
public function testShortString() {
$this->assertEquals("1 3",
tokenTruncate("1 3", 10));
}
public function testStringTooLong() {
$this->assertEquals("",
tokenTruncate("toooooooooooolooooong", 10));
}
public function testContainingNewline() {
$this->assertEquals("1 3\n5 7 9 ",
tokenTruncate("1 3\n5 7 9 11 14", 10));
}}
编辑:
没有处理像“à”这样的特殊UTF 8字符。在REGEX末尾添加“u”以处理它:
$parts = preg_split('/([\s\n\r]+)/u', $string, null, PREG_SPLIT_DELIM_CAPTURE);