css溢出与换行该如何处理

html-css020

css溢出与换行该如何处理,第1张

<div class"p">我是长长长长长长长长长长长长长长长长长长长长文字</div> .p{

    width:200px

    overflow: hidden

    text-overflow:ellipsis

    white-space: nowrap

}

可以这样弄,给他设置一个宽度,然后设置强制不换行,超出部分隐藏,超出文字设置成省略号

导致换行因素很多,看你怎么定义的了,但总体上来说大多是:溢出换行,内容超过了父元素可用空间,会换行。

可以考虑的解决方法:

强制限制各个子元素(你的三行元素)长度,确保三列总宽度不超过父元素的可用宽度(三行元素的内外边距和边框易被人为忽略导致总宽度超过可用宽度的100%)。这种情况常出现在浮动元素上。

<div id="fa">

    <div id="sub1"></div>

    <div id="sub2"></div>

    <div id="sub3"></div>

</div>

<!--

(#sub1+#sub2+sub3)的实际宽度 小于或等于 #fa的可用宽度

实际宽度 = sub的内外边距+边框+可用宽度

-->

不同的定义会有不同原因的,最好贴出你的代码,好让大家帮你解决。

用CSS让文字在一行内显示不换行的方法:

一般的文字截断(适用于内联与块):

.text-overflow{

display:block             /*内联对象需加*/

width:31em

word-break:keep-all       /* 不换行 */

white-space:nowrap        /* 不换行 */

overflow:hidden           /* 内容超出宽度时隐藏超出部分的内容 */

text-overflow:ellipsis    /*溢出时显示省略标记...;需与overflow:hidden一起使用*/

}

对于表格,定义有点不一样:

table{

width:30em

table-layout:fixed      /*只有定义了表格的布局算法为fixed,下面td的定义才能起作用*/

}

td{

width:100%

word-break:keep-all     /* 不换行 */

white-space:nowrap      /* 不换行 */

overflow:hidden         /* 内容超出宽度时隐藏超出部分的内容 */

text-overflow:ellipsis  /* 溢出时显示省略标记...;需与overflow:hidden一起使用*/

}

注:这个只对单行的文字的效,如果你想把它用在多行上,也只有第一行有作用的。 这个写法只有IE会有"...",其它的浏览器文本超出指定宽度时会隐藏。

层叠样式表(英文全称:Cascading Style Sheets)是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集)等文件样式的计算机语言。CSS不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。

CSS 能够对网页中元素位置的排版进行像素级精确控制,支持几乎所有的字体字号样式,拥有对网页对象和模型样式编辑的能力。