사실 요 며칠간 프로젝트 작업으로 바빠서 요약할 게 많은데, 가로채기 문제로 며칠간 혼란스러웠습니다. Smarty 템플릿에 중국어와 영어가 섞인 문자열이 드디어 해결되었으니 녹음이 필요한 친구들이 살펴보세요:
문자가 깨졌던 이유:
문자열 가로채기 기능은 영어 사용자에게만 적합합니다. 또한, 중국어와 영어가 혼합된 문자열의 경우 가로채기 기능을 사용하면 문자가 깨져서 표시됩니다. 같은 숫자의 문자열은 다릅니다. 중국어 문자열의 길이는 두 영어 단어의 길이와 거의 같습니다. 또한 truncate는 GB2312, UTF-8 및 기타 인코딩과 동시에 호환되지 않습니다.
해결책: 확장 클래스를 직접 작성하고
ThinkPHP에서 사용하는 smarty truncate 변수 조절기가 있는 클래스 파일의 위치 : ThinkPHPLibraryVendorSmartyplugins 중 하나는 modifier.truncate.php입니다. 우리는 이것을 구현하기 위해 직접 작성합니다.
파일 이름: modifier.smartTruncate.php
<?<span>php </span><span>/*</span><span>* * 中英文多编码字符串截取 </span><span>*/</span><span>function</span> smartDetectUTF8(<span>$string</span><span>) { </span><span>static</span><span>$result</span> = <span>array</span><span>(); </span><span>if</span>(! <span>array_key_exists</span>(<span>$key</span> = <span>md5</span>(<span>$string</span>), <span>$result</span><span>)) { </span><span>$utf8</span> = "<span> /^(?: [\x09\x0A\x0D\x20-\x7E] # ASCII | [\xC2-\xDF][\x80-\xBF] # non-overlong 2-byte | \xE0[\xA0-\xBF][\x80-\xBF] # excluding overlongs | [\xE1-\xEC\xEE\xEF][\x80-\xBF]{2} # straight 3-byte | \xED[\x80-\x9F][\x80-\xBF] # excluding surrogates | \xF0[\x90-\xBF][\x80-\xBF]{2} # planes 1-3 | [\xF1-\xF3][\x80-\xBF]{3} # planes 4-15 | \xF4[\x80-\x8F][\x80-\xBF]{2} # plane 16 )+$/xs </span>"<span>; </span><span>$result</span>[<span>$key</span>] = <span>preg_match</span>(<span>trim</span>(<span>$utf8</span>), <span>$string</span><span>); } </span><span>return</span><span>$result</span>[<span>$key</span><span>]; } </span><span>function</span> smartStrlen(<span>$string</span><span>) { </span><span>$result</span> = 0<span>; </span><span>$number</span> = smartDetectUTF8(<span>$string</span>) ? 3 : 2<span>; </span><span>for</span>(<span>$i</span> = 0; <span>$i</span> < <span>strlen</span>(<span>$string</span>); <span>$i</span> += <span>$bytes</span><span>) { </span><span>$bytes</span> = <span>ord</span>(<span>substr</span>(<span>$string</span>, <span>$i</span>, 1)) > 127 ? <span>$number</span> : 1<span>; </span><span>$result</span> += <span>$bytes</span> > 1 ? 1.0 : 0.5<span>; } </span><span>return</span><span>$result</span><span>; } </span><span>function</span> smartSubstr(<span>$string</span>, <span>$start</span>, <span>$length</span> = <span>null</span><span>) { </span><span>$result</span> = ''<span>; </span><span>$number</span> = smartDetectUTF8(<span>$string</span>) ? 3 : 2<span>; </span><span>if</span>(<span>$start</span> < 0<span>) { </span><span>$start</span> = <span>max</span>(smartStrlen(<span>$string</span>) + <span>$start</span>, 0<span>); } </span><span>for</span>(<span>$i</span> = 0; <span>$i</span> < <span>strlen</span>(<span>$string</span>); <span>$i</span> += <span>$bytes</span><span>) { </span><span>if</span>(<span>$start</span> <= 0<span>) { </span><span>break</span><span>; } </span><span>$bytes</span> = <span>ord</span>(<span>substr</span>(<span>$string</span>, <span>$i</span>, 1)) > 127 ? <span>$number</span> : 1<span>; </span><span>$start</span> -= <span>$bytes</span> > 1 ? 1.0 : 0.5<span>; } </span><span>if</span>(<span>is_null</span>(<span>$length</span><span>)) { </span><span>$result</span> = <span>substr</span>(<span>$string</span>, <span>$i</span><span>); } </span><span>else</span><span> { </span><span>for</span>(<span>$j</span> = <span>$i</span>; <span>$j</span> < <span>strlen</span>(<span>$string</span>); <span>$j</span> += <span>$bytes</span><span>) { </span><span>if</span>(<span>$length</span> <= 0<span>) { </span><span>break</span><span>; } </span><span>if</span>((<span>$bytes</span> = <span>ord</span>(<span>substr</span>(<span>$string</span>, <span>$j</span>, 1)) > 127 ? <span>$number</span> : 1) > 1<span>) { </span><span>if</span>(<span>$length</span> < 1.0<span>) { </span><span>break</span><span>; } </span><span>$result</span> .= <span>substr</span>(<span>$string</span>, <span>$j</span>, <span>$bytes</span><span>); </span><span>$length</span> -= 1.0<span>; } </span><span>else</span><span> { </span><span>$result</span> .= <span>substr</span>(<span>$string</span>, <span>$j</span>, 1<span>); </span><span>$length</span> -= 0.5<span>; } } } </span><span>return</span><span>$result</span><span>; } </span><span>function</span> smarty_modifier_smartTruncate(<span>$string</span>, <span>$length</span> = 80, <span>$etc</span> = '...',<span>$break_words</span> = <span>false</span>, <span>$middle</span> = <span>false</span><span>) { </span><span>if</span> (<span>$length</span> == 0<span>) </span><span>return</span> ''<span>; </span><span>if</span> (smartStrlen(<span>$string</span>) > <span>$length</span><span>) { </span><span>$length</span> -= smartStrlen(<span>$etc</span><span>); </span><span>if</span> (!<span>$break_words</span> && !<span>$middle</span><span>) { </span><span>$string</span> = <span>preg_replace</span>('/\s+?(\S+)?$/', '', smartSubstr(<span>$string</span>, 0, <span>$length</span>+1<span>)); } </span><span>if</span>(!<span>$middle</span><span>) { </span><span>return</span> smartSubstr(<span>$string</span>, 0, <span>$length</span>).<span>$etc</span><span>; } </span><span>else</span><span> { </span><span>return</span> smartSubstr(<span>$string</span>, 0, <span>$length</span>/2) . <span>$etc</span> . smartSubstr(<span>$string</span>, -<span>$length</span>/2<span>); } } </span><span>else</span><span> { </span><span>return</span><span>$string</span><span>; } } </span>?>
참고: 문자 길이를 판단할 때 한자 1자는 1.0, 영문 1자는 0.5로 계산됩니다.
사용방법:
{<span>$content</span>|smartTruncate:5:"..."}
네, 테스트에 문제가 없다면 지적해주세요. 궁금한 점
위 내용은 스마트 템플릿과 thinkphp 콘텐츠를 포함하여 ThinkPHP Smarty 템플릿에서 중국어와 영어가 혼합된 왜곡된 문자열을 가로채는 솔루션을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.