这里是后加上ellipsis
你的修复ED的方法:
$body = "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam eu congue ex. Nunc sem arcu, fermentum vel feugiat quis, consequat nec enim. Quisque et pulvinar velit, et laoreet justo. Integer quis sapien ac turpis mattis lobortis at at metus. Vestibulum euismod turpis odio, id luctus quam pharetra, at, et. Sed finibus, nunc at ultricies posuere, dui mauris aliquet quam, eget aliquet ligula libero a turpis. Pellentesque eu diam sodales, sollicitudin leo et, sagittis magna. Donec feugiat, velit quis condimentum porttitor, enim sapien varius elit, sit amet pretium risus turpis vitae massa. Sed ac ligula sit amet lorem scelerisque tristique a id ex. Nullam maximus tincidunt magna, vel molestie lectus tempus non. Sed euismod placerat ultricies. Morbi dapibus augue ut odio faucibus, vel maximus nisl pharetra. Aliquam hendrerit dolor in ipsum pharetra, eget tincidunt lacus ultrices.";
$line = $body;
if(strlen($body) > 300 && preg_match('/^(.{1,300})(?!\w)\b\p{P}*/su', $body, $match)) {
$line = trim($match[1]) . "…";
}
echo $line;
见eval.in demo
正如我在评论中指出,可以匹配标点符号(可选,与\p{P}*
),但我忘了\b
可以同时匹配尾随和领先字边界。通过限制\b
的负向预测(?!\w)
(如(?!\w)\b
)我们只匹配尾随字边界。
此外,捕获组((...)
)被添加到图案,使得我们只捕获成1组字符串以尾随标点符号修剪出来,并且该值可以与$match[1]
被访问。
尝试使用'/ ^(。{1,300})\ b \ p {P} */su''匹配尾部标点并仅使用trim($ match [1])。 “…”;'。 –
只使用wordwrap –
@WiktorStribiżew没有工作 - [eval.in](https://eval.in/508404) –