css文本自动省略问题

稿件来源: 阳光企业网站管理系统   撰稿作者: 太阳光   发表日期: 2014-11-07   阅读次数: 26   查看权限: 游客查看

css文本自动省略问题

在网页中,文本超长处理方法常常我们是使用css限制。当然也常常有人非得后台程序硬去截取字符,结果即对不齐又不利seo优化。

width:585px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;

如上css在一个块内,定义宽度后禁止换行超出隐藏并以省略号显示,是最佳选择。

可是某个时候能不能在第二行或者多行的最后一行省略呢?

我们找到一个css3属性-webkit-line-clamp

<p style="
  overflow : hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;/*表示第2行末尾省略*/
  -webkit-box-orient: vertical;
">好长好的内容</p>

很可惜它没在css3规范草案中,也局限在webkit浏览器中,firefox、IE等不支持,注定不能生存。

没办法,我们暂时用javascript替换着。

<div style="width: 200px;height: 40px">
    <p>很长很长的文本</p>
</div>
<script>
$(function(){
    $("div").each(function(i){
        var divH = $(this).height();
        var $p = $("p", $(this));
        while ($p.outerHeight() > divH) {
            $p.text($p.text().replace(/\s*.(\.{3})?$/, "..."));
        }
    });
})
</script>

原理就是每减少一个文字然后判断一下高度是否高过父节点,如果循环赶到符合条件。

关键词: css省略,ellipsis   编辑时间: 2014-11-07 16:42:52

  • 感到高兴

    0

    高兴
  • 感到支持

    0

    支持
  • 感到搞笑

    0

    搞笑
  • 感到不解

    0

    不解
  • 感到谎言

    0

    谎言
  • 感到枪稿

    0

    枪稿
  • 感到震惊

    0

    震惊
  • 感到无奈

    0

    无奈
  • 感到无聊

    0

    无聊
  • 感到反对

    0

    反对
  • 感到愤怒

    0

    愤怒
100%(1)
0%(0)
共有0 条评论 发言请遵守【相关规定

网友评论

会员头像
发 表同步腾讯微博    验证码:  点击更新请先登陆
  • 暂无评论
关闭模块文章图片 article Pictrue
  • 我的妈妈爸爸
  • 基于koa2+mysql+vue2.0+Element阳光内容管理系统
  • 代码覆盖率工具 Istanbul 入门教程
  • 全栈工程师的武器——MEAN
  • 9款超炫的 CSS3 复选框(Checkbox)
  • 微信开发在线翻译功能
  • CSS3那些不为人知的高级属性
  • 给easyui的datebox添加清空事件
  • flash写字效果
  • kendoUI系列教程之DropDownList下拉菜单
  • kendoUI系列教程之datetimepicker日期时间选择
  • kendoUI系列教程之datepicker日期选择
  • kendoUI系列教程之combobox下拉列表框
  • kendoUI系列教程之colorpicker
  • kendoUI系列教程之calendar日历表
  • kendoUI系列教程之autocomplete自动补齐