Diz*_*zzi 4 html php function substr
正如标题所说,我想在不破坏任何单词或 HTML 标签的情况下剪切一个字符串,现在我发现了这个功能可以解决 html 标签问题(我自己稍微修改了)
function substrhtml($str,$start,$len){
$str_clean = substr(strip_tags($str),$start,$len);
if(preg_match_all('/\<[^>]+>/is',$str,$matches,PREG_OFFSET_CAPTURE)){
for($i=0;$i<count($matches[0]);$i++){
if($matches[0][$i][1] < $len){
$str_clean = substr($str_clean,0,$matches[0][$i][1]) . $matches[0][$i][0] . substr($str_clean,$matches[0][$i][1]);
}else if(preg_match('/\<[^>]+>$/is',$matches[0][$i][0])){
$str_clean = substr($str_clean,0,$matches[0][$i][1]) . $matches[0][$i][0] . substr($str_clean,$matches[0][$i][1]);
break;
}
}
return $str_clean;
}else{
return substr($str,$start,$len);
}
}
Run Code Online (Sandbox Code Playgroud)
但它仍然将我不想发生的半句中的单词剪掉,关于如何对此进行排序的任何想法?
一如既往地感谢任何帮助并提前致谢。
小智 5
尝试这个:
function substrhtml($str,$start,$len){
$str_clean = substr(strip_tags($str),$start,$len);
$pos = strrpos($str_clean, " ");
if($pos === false) {
$str_clean = substr(strip_tags($str),$start,$len);
}else
$str_clean = substr(strip_tags($str),$start,$pos);
if(preg_match_all('/\<[^>]+>/is',$str,$matches,PREG_OFFSET_CAPTURE)){
for($i=0;$i<count($matches[0]);$i++){
if($matches[0][$i][1] < $len){
$str_clean = substr($str_clean,0,$matches[0][$i][1]) . $matches[0][$i][0] . substr($str_clean,$matches[0][$i][1]);
}else if(preg_match('/\<[^>]+>$/is',$matches[0][$i][0])){
$str_clean = substr($str_clean,0,$matches[0][$i][1]) . $matches[0][$i][0] . substr($str_clean,$matches[0][$i][1]);
break;
}
}
return $str_clean;
}else{
$string = substr($str,$start,$len);
$pos = strrpos($string, " ");
if($pos === false) {
return substr($str,$start,$len);
}
return substr($str,$start,$pos);
}
}
$string = '<h1>How to cut the string without breaking any words</h1>';
echo substrhtml($string,0,28);
?>
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
5862 次 |
最近记录: |