zoukankan      html  css  js  c++  java
  • html文字两行后,就用省略号代替剩下的

    html文字两行后,就用省略号代替剩下的

    一、总结

    一句话总结:

    实现原理很简单,将box的高度设置为行高的两倍,超出之后隐藏,这样就只有两行了,然后再用after属性绝对定位在第二行后面加几个点 ...
      .style2{
          position:relative;
          line-height:21px;
          height:42px; /*height是line-height的整数倍,防止文字显示不全*/
          overflow:hidden;
      }
      .style2::after {
          background: linear-gradient(to right, rgba(255, 255, 255, 0), #FFFFFF 50%) repeat scroll 0 0 rgba(0, 0, 0, 0);
          bottom: 0;
          content: "...";
          padding: 0 5px 1px 30px;
          position: absolute;
          right: 0;
      }

    1、一行截断效果?

    注意设置宽高,剩下的就是记住用white-space(不换行),overflow(超出部分隐藏),text-overflow(隐藏使用的替代符号)
      .font_cut{
          width: 100%;
          white-space:nowrap;
          overflow:hidden;
          text-overflow: ellipsis;
      }

    2、after属性里面如何指定内容?

    content: "...";
      .style2::after {
          background: linear-gradient(to right, rgba(255, 255, 255, 0), #FFFFFF 50%) repeat scroll 0 0 rgba(0, 0, 0, 0);
          bottom: 0;
          content: "...";
          padding: 0 5px 1px 30px;
          position: absolute;
          right: 0;
      }

    3、after属性里面可以绝对定位么?

    可以,操作after属性就和操作普通样式一样
      .style2::after {
          background: linear-gradient(to right, rgba(255, 255, 255, 0), #FFFFFF 50%) repeat scroll 0 0 rgba(0, 0, 0, 0);
          bottom: 0;
          content: "...";
          padding: 0 5px 1px 30px;
          position: absolute;
          right: 0;
      }

    二、html文字两行后,就用省略号代替

    1、效果图

    2、代码

     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title>Document</title>
     6     <style>
     7         .font_cut{
     8             width: 100%;
     9             white-space:nowrap;
    10             overflow:hidden;
    11             text-overflow: ellipsis;
    12         }
    13         .style2{
    14             position:relative;
    15             line-height:21px;
    16             height:42px; /*height是line-height的整数倍,防止文字显示不全*/
    17             overflow:hidden;
    18         }
    19         .style2::after {
    20             background: linear-gradient(to right, rgba(255, 255, 255, 0), #FFFFFF 50%) repeat scroll 0 0 rgba(0, 0, 0, 0);
    21             bottom: 0;
    22             content: "...";
    23             padding: 0 5px 1px 30px;
    24             position: absolute;
    25             right: 0;
    26         }
    27 
    28     </style>
    29 
    30 
    31 </head>
    32 <body>
    33     <div class="font_cut" style=" 300px;">
    34         <span>一行显示不下,就用省略号代替;一行显示不下,就用省略号代替;一行显示不下,就用省略号代替;一行显示不下,就用省略号代替;一行显示不下,就用省略号代替;一行显示不下,就用省略号代替;</span>
    35     </div>
    36     <div style="margin-bottom: 60px;"></div>
    37     <div class="style2" style=" 300px;">
    38         <span style="" class="">HTML文字超过两行以后 就用省略号显示代替;HTML文字超过两行以后 就用省略号显示代替;HTML文字超过两行以后 就用省略号显示代替;HTML文字超过两行以后 就用省略号显示代替;HTML文字超过两行以后 就用省略号显示代替;HTML文字超过两行以后 就用省略号显示代替;</span>
    39     </div>
    40 </body>
    41 </html>

    三、html文字超出两行,则显示省略号

    转自或参考:html文字超出两行,则显示省略号
    https://blog.csdn.net/camillezj/article/details/52767267

     

    多行超出显示省略号

    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2; //2行
    -webkit-box-orient: vertical;
    注意:-webkit-line-clamp是一个 不规范的属性(unsupported WebKit property),它没有出现在 CSS 规范草案中。只适用于WebKit内核的浏览器,因此firebox、ie等并不支持该属性。

    其他浏览器做法:

    比较靠谱简单的做法就是设置相对定位的容器高度,用包含省略号(…)的元素模拟实现:
    文字容器样式设置:

    position:relative;
    line-height:1.4em;
    height:4.2em; //height是line-height的整数倍,防止文字显示不全
    overflow:hidden;

    文字容器::after {
    background: linear-gradient(to right, rgba(255, 255, 255, 0), #FFFFFF 50%) repeat scroll 0 0 rgba(0, 0, 0, 0);
    bottom: 0;
    content: "...";
    padding: 0 5px 1px 30px;
    position: absolute;
    right: 0;
    }

    或者使用插件:js插件-Clamp.js 、 jquery插件-jQuery.dotdotdot

    单行不换行:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;

     
     
  • 相关阅读:
    自定义GridView分页控件
    ASP.NET中JSON的序列化和反序列化 C#的JSON数据格式转换方法
    C# 中 Struct 与 Class 的区别,以及两者的适用场合
    IEnumerable
    谈谈C#中的三个关键词new , virtual , override
    常见通信协议
    当base-package="controller.*"时,可见packageSearchPath为"classpath*:controller/*/**/*.class": 当base-package="controller.**"时,可见packageSearchPath为"classpath*:controller/**/**/*.class":
    DO,DTO和VO的使用
    mysql 字符
    mysql sql 分析
  • 原文地址:https://www.cnblogs.com/Renyi-Fan/p/11776986.html
Copyright © 2011-2022 走看看