javascript控制文字显示一行半,超出内容显示省略号

  在前端开发过程中,实现文本超出一行或者两行,多余部分显示省略号,使用css实现起来比较简单,但是如果想要实现文本超出一行半或者两行半,多余部分显示省略号,使用css则无法实现,但使用javascript可以做到。如下:

  html部分:

 样式:

  js部分:

  这里已经封装好了方法jsLine(line,className),可以直接拿去用的,其中line参数是控制文本显示的行数,一行半就是1.5,两行半2.5,className是要控制的文本类名,记住要使用类选择器哦。
  实现原理:
  利用文本宽度/文本大小= 一行有多少字符,然后一行有多少字符*需要控制的行数=需要显示的字符数,需要显示的字符数有了,后面的就简单了,用substr()截取就行了。
            
  这里面会遇到一个问题,如果没有对当前的文本font-size属性做设置的话,dom[0].style.fontSize会获取不到文本大小,有的朋友可能会说不设置那就是浏览器默认字体大小了,但是当前文本可能会继承其父类的font-size属性,也就是说并不是浏览器默认字体大小。那应该怎么解决呢?
            
  var fontSize=getComputedStyle(className[0],undefined).getPropertyValue("font-size")
  这行代码能让你获取浏览器渲染之后的字体大小。 

猜你喜欢

转载自blog.csdn.net/qq_21473443/article/details/129841540