以下代码适用于chrome。
但不是在Firefox或IE上。将<!DOCTYPE html>
标记添加到此代码中会导致它无法处理Chrome。 text-overflow
被弃用了吗?如何使其与所有浏览器和HTML5兼容?
<head>
<style type='text/css'>
table {
display: block;
margin: 30px 0 auto 0;
width: 100%;
max-width: 1300px;
text-align: left;
white-space: nowrap;
border-collapse: collapse;
z-index: -1;
table-layout:fixed;
}
td {
overflow: hidden;
white-space: nowrap;
word-wrap:break-word;
text-overflow:ellipsis;
border: 1px solid black;
}
</style>
</head>
<body>
<table>
<tr>
<th style="width: 18%;">Col 1</th>
<th style="width: 12%;">Col 2</th>
<th style="width: 13%;">Col 3</th>
<th style="width: 7%">Col 4</th>
<th style="width: 7%">Col 5</th>
<th style="width: 6%">Col 6</th>
<th style="width: 5%">Col 7</th>
<th style="width: 13%">Col 8</th>
<th style="width: 16%">Col 9</th>
<th style="width: 3%">Col 10</th>
</tr>
<tr>
<td>Some</td>
<td>Data</td>
<td>Stuff</td>
<td>foo</td>
<td>bar</td>
<td>etc</td>
<td>whatever</td>
<td>stuff</td>
<td>Alotofdataikkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk</td>
<td>Yes</td>
</tr>
</table>
</body>
这就是我想要的。
答案 0 :(得分:1)
为你的td添加最大宽度。
td{
overflow: hidden;
white-space: nowrap;
word-wrap:break-word;
text-overflow:ellipsis;
border: 1px solid black;
max-width: 50px;
}
答案 1 :(得分:1)
您滥用了文本溢出属性。
如果要包装元素的文本,则必须指定该元素的宽度或最大宽度,以便浏览器知道如何包装文本内容。
[EDITED] 这是示例代码:
<head>
<style type='text/css'>
table {
display: block;
margin: 30px 0 auto 0;
/*width: 100%;*/
max-width: 900px;
text-align: left;
white-space: nowrap;
border-collapse: collapse;
z-index: -1;
table-layout:fixed;
}
td {
overflow: hidden;
white-space: nowrap;
word-wrap:break-word;
text-overflow: ellipsis;
border: 1px solid black;
}
.col1 {
width: 80px;
}
.col7 {
max-width: 300px;
}
.col8 {
max-width: 300px;
}
</style>
</head>
<body>
<table>
<tr>
<th class="col1">Col 1</th>
<th class="col2">Col 2</th>
<th class="col3">Col 3</th>
<th class="col4">Col 4</th>
<th class="col5">Col 5</th>
<th class="col6">Col 6</th>
<th class="col7">Col 7</th>
<th class="col8">Col 8</th>
<th class="col9">Col 9</th>
<th class="col10">Col 10</th>
</tr>
<tr>
<td class="col1">Some</td>
<td class="col2">Data</td>
<td class="col3">Stuff</td>
<td class="col4">foo</td>
<td class="col5">etc</td>
<td class="col6">whatever</td>
<td class="col7">stuff</td>
<td class="col8">Alotofdataikkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk</td>
<td class="col9">Yes</td>
<td class="col10">bar</td>
</tr>
<tr>
<td class="col1">Some</td>
<td class="col2">Data</td>
<td class="col3">Stuff</td>
<td class="col4">foo</td>
<td class="col5">etc</td>
<td class="col6">whatever</td>
<td class="col8">Alotofdataikkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk</td>
<td class="col7">stuff</td>
<td class="col9">Yes</td>
<td class="col10">bar</td>
</tr>
</table>
</body>
以下是演示屏幕截图:
答案 2 :(得分:0)
text-overflow: ellipsis
在HTML5中运行良好。我认为display: block
正在制造一些问题。尝试删除它或将其替换为display: table
并检查它是否有效。