php中怎么对输出的文章限制字数,剩余的用“.”表示

php中如何对输出的文章限制字数,剩余的用“.(重复)”表示?
由于文章内容太多,搞得整个网页都变形了,所以就想通过只输出一部分,其他内容用省略号表示,
也在网上找了很多方法都行不通的,CSS啊,php中substr等函数那些都搞不好,希望能得到帮助!谢谢

代码如下:

'.$value['content'].'

function mbSubStr($str, $length = 0, $append = true)
{
  $str = trim($str);
  $strlength = strlen($str);
  if ($length == 0 || $length >= $strlength) {
    return $str; //截取长度等于0或大于等于本字符串的长度,返回字符串本身
  }elseif ($length < 0){ //如果截取长度为负数
    $length = $strlength + $length;//那么截取长度就等于字符串长度减去截取长度
    if ($length < 0) {
      $length = $strlength;//如果截取长度的绝对值大于字符串本身长度,则截取长度取字符串本身的长度
    }
  }
  if (function_exists('mb_substr')){
    $newstr = mb_substr($str, 0, $length, 'utf-8');
  }elseif (function_exists('iconv_substr')){
    $newstr = iconv_substr($str, 0, $length, 'utf-8');
  }else{
    $newstr = substr($str, 0, $length);
  }

  if ($append && $str != $newstr){
    $newstr .= '...';
  }
  return $newstr;
}

css 样式就可以实现。如果是要用php截取字符串可以使用mb_substr,保证不出现乱码。

设置css样式

  width: 50px;  //容器宽度
  word-break: break-all;
  text-overflow: ellipsis;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 4; //行数
  -webkit-box-orient: vertical;

建议使用js
1.不建议从后端控制,因为文章网页的第一要素就是保证内容完整性
2.css控制可以达到效果,但是也没法保证内容完整性
3.js控制缩略(推荐) 既可以保证内容可以完整的在html源代码中呈现,又能保证在视图中不影响用户浏览,还可以添加按钮进行展开阅读

谢谢各位大佬