<?php
function strimwidthCenter( $value, $length = 40 ) {
$valueEncoding = mb_detect_encoding( $value, 'auto', true );
if ( $length >= mb_strwidth( $value, $valueEncoding ) ) {
return $value;
}
$limited = '';
$firstWidth = ceil( $length/2 );
$secondStart = mb_strwidth( $value, $valueEncoding ) - ( $length - $firstWidth );
$secondWidth = $length - $firstWidth +1;
$limited = mb_strimwidth( $value, 0, $firstWidth, '...', $valueEncoding ) . mb_substr( $value, $secondStart, $secondWidth, $valueEncoding );
return $limited;
}
?>
mb_strimwidth
(PHP 4 >= 4.0.6, PHP 5)
mb_strimwidth — Tronque une chaîne
Description
string mb_strimwidth
( string $str
, int $start
, int $width
[, string $trimmarker
[, string $encoding
]] )
Tronque la chaîne str à la longueur width .
Liste de paramètres
- str
-
La chaîne à tronquer.
- start
-
start est l'offset de départ, en nombre de caractères depuis le début de la chaîne (cela commence à 0).
- width
-
La taille à tronquer.
- trimmarker
-
trimmarker est la chaîne ajoutée à la fin de la chaîne tronquée.
- encoding
-
Le paramètre encoding est l'encodage des caractères. S'il est omis, l'encodage de caractres interne sera utilisé.
Valeurs de retour
La chaîne tronquée. Si trimmarker est défini, trimmarker sera ajouté à la valeur retournée.
Exemples
Exemple #1 Exemple avec mb_strimwidth()
<?php
$str = mb_strimwidth($str, 0, 40, "..>");
?>
Voir aussi
- mb_strwidth() - Retourne la taille d'une chaîne
- mb_internal_encoding() - Lit/modifie l'encodage interne
mb_strimwidth
CBieser
26-Aug-2008 07:50
26-Aug-2008 07:50
josiah dot ritchie at gmail dot com
13-Sep-2007 06:48
13-Sep-2007 06:48
While having the option to append a string to the end is nice, you can run into the problem of having a space between the append if the width is truncated after a space. I find something like this to be more attractive in the output, although messy in the code.
rtrim(mb_strimwidth($string, 0, 24))."..."
