โดยใช้ฟังก์ชั่นwordwrap มันแยกข้อความในหลายบรรทัดเช่นที่ความกว้างสูงสุดคือคนที่คุณระบุแบ่งที่ขอบเขตของคำ หลังจากแยกคุณเพียงใช้บรรทัดแรก:
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 < $parts_count; ++$last_part) {
$length += strlen($parts[$last_part]);
if ($length > $your_desired_width) { break; }
}
return implode(array_slice($parts, 0, $last_part));
}
นอกจากนี้ที่นี่ PHPUnit testclass ใช้ในการทดสอบการใช้งาน:
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));
}
}
แก้ไข:
ไม่สามารถจัดการอักขระ UTF8 พิเศษเช่น 'à' เพิ่ม 'u' ในตอนท้ายของ REGEX เพื่อจัดการ:
$parts = preg_split('/([\s\n\r]+)/u', $string, null, PREG_SPLIT_DELIM_CAPTURE);