Truncate string to given maximum length without breaking words
This method can truncate between words, sentences, punctuation or blocks (like paragraphs).
type option for details on how it should truncate. By default it truncates between
words. Description of types:
- word: truncate to closest word.
- punctuation: truncate to closest punctuation within sentence.
- sentence: truncate to closest sentence.
- block: truncate to closest block of text (like a paragraph or headline).
Note that if your specified
type is something other than “word”, and it cannot be matched
within the maxLength, then it will attempt a different type. For instance, if you specify
“sentence” as the type, and it cannot match a sentence, it will try to match to “punctuation”
instead. If it cannot match that, then it will attempt “word”.
HTML will be stripped from returned string. If you want to keep some tags use the
options to specify what tags are allowed to remain. The
keepFormatTags option that, when true, will make it
retain all HTML inline text formatting tags.
Available since version 3.0.101.
// Truncate string to closest word within 150 characters $s = $sanitizer->truncate($str, 150); // Truncate string to closest sentence within 300 characters $s = $sanitizer->truncate($str, 300, 'sentence'); // Truncate with options $s = $sanitizer->truncate($str, [ 'type' => 'punctuation', 'maxLength' => 300, 'visible' => true, 'more' => '…' ]);
// basic usage $string = $sanitizer->truncate(string $str); // usage with all arguments $string = $sanitizer->truncate(string $str, $maxLength = 300, $options = );
String to truncate
Maximum length of returned string, or specify $options array here.
Options array, or specify
API reference based on ProcessWire core version 3.0.148