• 当文字过长时裁剪(显示省略号或只裁剪 用CSS方法,不用程序)


    原文发布时间为:2009-09-16 —— 来源于本人的百度文章 [由搬家工具导入]

    CSS中ellipsis()应用【转】

    CSS手册中text-overflow属性的定义:

      语法:
    text-overflow : clip | ellipsis

    参数:
    clip :  不显示省略标记(...),而是简单的裁切
    (clip这个参数是不常用的!)
    ellipsis :  当对象内文本溢出时显示省略标记(...)

    说明:
    设置或检索是否使用一个省略标记(...)标示对象内文本的溢出。
    请您注意,text-overflow:ellipsis属性在FF中是没有效果的。

      示例:
    div { text-overflow : clip; }

      text-overflow是一个比较特殊的样式,我们可以用它代替我们通常所用的标题截取函数,而且这样做对 搜索引擎更加友好,如:标题文件有50个汉字,而我们的列表可能只有300px的宽度。如果用标题截取函数,则标题不是完整的,如果我们用CSS样式 text-overflow:ellipsis,输出的标题是完整的,只是受容器大小的局限不显示出来罢了。

      关于text-overflow属性如何应用,我们作如下的说明讲解:

      text-overflow属性仅是注解,当文本溢出时是否显示省略标记。并不具备其它的样式属性定义。我们想 要实现溢出时产生省略号的效果。还必须定义:强制文本在一行内显示(white-space:nowrap)及溢出内容为隐藏(overflow: hidden)。只有这样才能实现溢出文本显示省略号的效果。

      我们首页建立了一个无序列表UL,里面有几个列表项LI,内部建立了列表链接A。我们的测试主要在LI在进行,请注意观察,看如下的三段代码:

      一、仅定义text-overflow:ellipsis; 不能实现省略号效果。

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    <title>it55</title>
    <style type="text/css">
    ul {300px; margin:50px auto;}
    li {300px; line-height:25px; text-overflow:ellipsis;}
    a {color:#03c; font-size:13px;}
    a:hover {color:#000;}
    </style>
    </head>
    <body>
    <ul>
    <li><a href="/">CSS实战精萃 - Pro CSS Techniques </a>
    <li><a href="/">CSS实战:id是狙击枪 class是双刃剑 合则两利分则两败</a>
    <li><a href="/">CSS布局实例:CSS标签切换代码实例教程</a>
    <li><a href="/">Web标准:改变您的网页制作思维方式 节省代码及结构与表现分离</a>
    <li><a href="/">解决IE7以下版本不支持无A状态伪类的几种方法!</a>
    <li><a href="/">CSS去除表格td默认间距及制作1px细线表格 </a>
    </ul>

    </body>
    </html>

    二、定义text-overflow:ellipsis; white-space:nowrap; 同样不能实现省略号效果。

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    <title>it55</title>
    <style type="text/css">
    ul {300px; margin:50px auto;}
    li {300px; line-height:25px; text-overflow:ellipsis; white-space:nowrap;}
    a {color:#03c; font-size:13px;}
    a:hover {color:#000;}
    </style>
    </head>
    <body>
    <ul>
    <li><a href="/">CSS实战精萃 - Pro CSS Techniques </a>
    <li><a href="/">CSS实战:id是狙击枪 class是双刃剑 合则两利分则两败</a>
    <li><a href="/">CSS布局实例:CSS标签切换代码实例教程</a>
    <li><a href="/">Web标准:改变您的网页制作思维方式 节省代码及结构与表现分离</a>
    <li><a href="/">解决IE7以下版本不支持无A状态伪类的几种方法!</a>
    <li><a href="/">CSS去除表格td默认间距及制作1px细线表格 </a>
    </ul>
    </body>
    </html>

    三、按it55.com的教程,即本文所讲的方法,同时应用: text-overflow:ellipsis; white-space:nowrap; overflow:hidden; 实现了所想要得到的溢出文本显示省略号效果:

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    <title>it55</title>
    <style type="text/css">
    ul {300px; margin:50px auto;}
    li {300px; line-height:25px; text-overflow:ellipsis; white-space:nowrap; overflow:hidden;}
    a {color:#03c; font-size:13px;}
    a:hover {color:#000;}
    </style>
    </head>
    <body>
    <ul>
    <li><a href="/">CSS实战精萃 - Pro CSS Techniques </a>
    <li><a href="/">CSS实战:id是狙击枪 class是双刃剑 合则两利分则两败</a>
    <li><a href="/">CSS布局实例:CSS标签切换代码实例教程</a>
    <li><a href="/">Web标准:改变您的网页制作思维方式 节省代码及结构与表现分离</a>
    <li><a href="/">解决IE7以下版本不支持无A状态伪类的几种方法!</a>
    <li><a href="/">CSS去除表格td默认间距及制作1px细线表格 </a>
    </ul>
    </body>
    </html>

    请您特别注意,text-overflow:ellipsis属性在FF中是没有效果的。


    复制一下内容,直接拷贝到html文件中运行就可看到效果了
    <html>
    <head>
    <style>
    .text-overflow{
    display:block;/*内联对象需加*/
    200px;
    word-break:keep-all;/* 不换行 */
    white-space:nowrap;/* 不换行 */
    overflow:hidden;/* 内容超出宽度时隐藏超出部分的内容 */
    text-overflow:ellipsis;/* 当对象内文本溢出时显示省略标记(...) ;需与overflow:hidden;一起使用。*/
    }
    .table{
    300px;
    table-layout:fixed;/* 只有定义了表格的布局算法为fixed,下面td的定义才能起作用。 */
    }
    .table td{
    100%;
    word-break:keep-all;/* 不换行 */
    white-space:nowrap;/* 不换行 */
    overflow:hidden;/* 内容超出宽度时隐藏超出部分的内容 */
    text-overflow:ellipsis;/* 当对象内文本溢出时显示省略标记(...) ;需与overflow:hidden;一起使用。*/
    }
    </style>
    </head>
    <body>
    <div class="text-overflow">


    另外附上几条刚学到的页面设计的小经验
    1、页面中talbe的宽设置为100%右边还是会留下一个滚动条的空白,可以在body标记里在加上:

    <body style="overflow:auto">

    2、
    @font-face {font-family:comic;src:url(http://url/font.eot);}

    可以定义一个在本地没有的字体名称,调用方法:
    <span style="font-family:comic;">just cd boy!</span>

    3、firefox的document.createElement不支持内容里有HTML标签,也不支持innerText,但是支持innerHTML,可以用innerHTML指定其内容。

  • 相关阅读:
    java访问mysql方法数据库
    iOS8:把这些七招APP哭
    String、StringBuffer与StringBuilder差分
    陈词滥调,正确使用memset
    spring Annotation 组分注塑
    类是公共,它应该被命名为.java文件声明
    【UVA】10012
    Android在ListView显示图片(重复混乱闪烁问题)
    oc-15-枚举结构体
    oc-15-self
  • 原文地址:https://www.cnblogs.com/handboy/p/7158337.html
Copyright © 2020-2023  润新知