通过重构不是我写的旧代码,我发现了这段代码:
if(BESCHREIBUNG_PRODUKT_MAX_ZEICHEN != 0 && strlen($row['beschreibung']) > BESCHREIBUNG_PRODUKT_MAX_ZEICHEN){
$beschreibung = chunk_split($row['beschreibung'], BESCHREIBUNG_PRODUKT_MAX_ZEICHEN, 'x+x+x+');
$beschreibung_array = explode('x+x+x+', $beschreibung);
$beschreibung = $beschreibung_array[0].'...';
}
据我所知,字符串$row‘’beschreibung‘被分成若干部分,每个部分的长度由常量"BESCHREIBUNG_PRODUKT_MAX_ZEICHEN“和”x+“提供。然后,这个新字符串被附加的字符串“x+”拆分,结果是创建了一个数组。最后但并非最不重要的是,数组的第一项被赋值给变量"$beschreibung“和"...”是附加的。
我想知道substr resp.mb_substr,因为可以使用UTF-8作为输入字符串,因此可以避免创建无用的数组。
因此,我改进后的代码将如下所示:
if(BESCHREIBUNG_PRODUKT_MAX_ZEICHEN != 0 && strlen($row['beschreibung']) > BESCHREIBUNG_PRODUKT_MAX_ZEICHEN){
$beschreibung = mb_substr($row['beschreibung'], 0, BESCHREIBUNG_PRODUKT_MAX_ZEICHEN).'…';
}
我是否正确理解了这一点,或者在这种情况下使用chunk_split有什么好处,但我并不知道。
发布于 2021-08-11 03:33:28
有一个名为mb_strimwidth()
的特殊函数,请参阅此处:https://www.php.net/manual/en/function.mb-strimwidth.php
示例:
$beschreibung = mb_strimwidth($row['beschreibung'], 0, BESCHREIBUNG_PRODUKT_MAX_ZEICHEN, '...');
您不需要if
语句,因为如果BESCHREIBUNG_PRODUKT_MAX_ZEICHEN
为0
或比字符串更长,它将不会删除任何内容。
请注意,字符串长度包含3个点的...
mb_strimwidth("Hello",0,6,'...'); // output: "Hel..."
mb_strimwidth("Hello",0,0,'...'); // output: "Hello"
mb_strimwidth("Hello",0,20,'...'); // output: "Hello"
mb_strimwidth("Hello",0,5,'…'); // output: "Hell…" (utf-8 ellipsis)
https://stackoverflow.com/questions/68739889
复制