换行-white-space, word-wrap, word-break

本文介绍如何使用CSS实现块状元素和表格中的内容单行显示并超出部分自动隐藏的效果,适用于固定宽度布局,提升网页展示效果。

参看:http://blog.youkuaiyun.com/liu2835993/archive/2009/12/10/4977555.aspx

 

 

经常在项目中遇到换行问题,属性word-break只有在ie6、ie7下可用,故忽略。

 

注意: 此文只谈怎么让元素不换行,直接隐藏(在实际项目中一般不会出现,用户体验太差)

 

------------------------------------------------------------------------------------

 

1. 块状元素中(以div示例)

    如果需要单行显示,不换行,直接设置overflow:hidden, white-space:nowrap; width:xxx(指定宽度)

    备注: 不需要指定高度。

 

2. 表格中

    如果需要固定td的宽度,并且让td中的内容不换行,超出td宽度的内容自动隐藏,则需要做如下操作:

      1. table设置table-layout:fixed

      2. td设置nowrap; overflow:hidden

      3. tbody中的td不能设置宽度,td的宽度由thead中的td或者th来设置(这个相当关键)

 

 

示例:

 

如图: 

css代码:

 

.tableContainer{padding-bottom:100px;}

.tableContainer table{table-layout:fixed; border:solid 1px #ccf; width:800px; line-height:1.6em; vertical-align:middle;}

.tableContainer table thead th{background:#aaa; font-weight:bold; text-align:center; border:none; font-size:14px;}

.tableContainer table tbody td{overflow:hidden; padding:1px 6px; border:solid 1px #ccf; color:#000; text-align:right;}

 
------------------------------------------
html代码:
 

 

 

 <div class="tableContainer mt30">

                <table cellpadding="0" cellspacing="0">

                    <thead>

                    <tr>

                        <th width="20">序号</th>

                        <th width="50">姓名</th>

                        <th width="80">生日</th>

                        <th>邮箱</th>

                    </tr>

                    </thead>

                    <tbody>

                    <tr>

                        <td nowrap>11111111</td>

                        <td nowrap>这个全是中文全部是中文这个全是中文全部是中文这个全是中文全部是中文</td>

                        <td nowrap>this is all english This ! thisfk lakd laawwwwwwwlakdjfwwwwwwwww</td>

                        <td nowrap>wrap换行测试数据测试数据wwwwwwwwww&lt;&gt;wwwwmmmwwwmmm</td>

                    </tr>

                    <tr>

                        <td nowrap="nowrap">wrap换行测试数据测试数据wwwwwwwwww&lt;&gt;wwwwmmmwwwmmm</td>

                        <td nowrap="nowrap">wrap换行测试数据测试数据wwwwwwwwww&lt;&gt;看看中文看看中文</td>

                        <td nowrap>this is all english This ! thisfk lakd laawwwwwwwlakdjfwwwwwwwww</td>

                        <td nowrap>wrap换行测试数据测试数据wwwwwwwwww&lt;&gt;----------------</td>

                    </tr>

                    <tr>

                        <td nowrap>111111</td>

                        <td nowrap>这个全是中文全部是中文这个全是中文全部是中文这个全是中文全部是中文</td>

                        <td nowrap>this is all english This ! thisfk lakd laawwwwwwwlakdjfwwwwwwwww</td>

                        <td nowrap>wrap换行测试数据测试数据wwwwwwwwww&lt;&gt;wwwwmmmwwwmmm</td>

                    </tr>

                    <tr>

                        <td nowrap>wrap换行测试数据测试数据wwwwwwwwww&lt;&gt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;</td>

                        <td nowrap>wrap换行测试数据测试数据wwwwwwwwww&lt;&gt;&lt;&gt;&lt;&gt;&lt;&gt;&lt;&gt;&lt;&gt;&lt;&gt;</td>

                        <td nowrap>wrap换行测试数据测试数据wwwwwwwwww&lt;&gt;----------------</td>

                        <td nowrap>wrap换行测试数据测试数据wwwwwwwwww&lt;&gt;wwmmmmmmmmmwwmmmwwwmmm</td>

                    </tr>

                    </tbody>

                </table>

            </div>

转载于:https://www.cnblogs.com/chyong168/archive/2011/11/20/2256217.html

### 使用 `word-wrap` 和 `word-break` 实现换行效果 #### 属性解释 `word-wrap` 和 `word-break` 是 CSS 中用于控制文本换行行为的重要属性。 - **`word-wrap: break-word;`** 此属性主要用于处理超出容器宽度的内容,允许长单词或 URL 被拆分到下一行。它仅在必要时才会打断单词[^2]。 - **`word-break: break-all;`** 这一属性更加激进,会在任何字符处强行断开单词,即使不需要打破单词也会如此操作。这种特性非常适合包含大量英文或其他非亚洲语言的场景[^4]。 当应用于中文环境时,两者的区别主要体现在是否严格遵循语义分割上: - 对于纯中文内容来说,因为汉字之间不存在自然间隙(不像英文字母间存在空格),所以无论是采用 `word-wrap: break-word;` 或者是 `word-break: break-all;` 都能够正常工作并按需完成换行任务[^3]。 然而需要注意的是,在混合型文档——即既含有中文又夹杂着较长不可分割单元比如技术术语、链接地址等情况之下,则应仔细权衡选用哪一种策略更为合适[^1]。 以下是具体的应用实例以及代码展示部分: ```html <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>Word Wrap & Break Example</title> <style> .example { width: 200px; border: 1px solid black; margin-bottom: 10px; } /* Using word-wrap */ .use-word-wrap { white-space: pre-line; word-wrap: break-word; } /* Using word-break */ .use-word-break { white-space: normal; word-break: break-all; } </style> </head> <body> <div class="example use-word-wrap">这是一个非常长的单个词语aaaaaaaaaaaaaaaabbbbbbbbbbbbcccccccccccddddddddddeeeeeeeeee。</div> <div class="example use-word-break">这是另一个例子:http://www.example.com/verylongurlthatneedstobebrokenintopieces.</div> </body> </html> ``` 以上HTML片段展示了两种不同方法的实际运用情况。第一个 div 利用了 `word-wrap: break-word;` 来优雅地处理超长字符串;而第二个则通过设置 `word-break: break-all;` 达到了同样的目的却可能破坏某些特定场合下的可读性[^5]。 ### 结论 综上所述,在实际开发过程中可以根据项目需求灵活选择合适的解决方案。如果是针对一般性的网页布局设计,并且希望保持较好的用户体验,则推荐优先考虑使用 `word-wrap: break-word;` 。但如果面对特殊情形如表格内部单元格溢出等问题,则可以尝试引入更加强硬的方式 —— 即启用 `word-break: break-all;`.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值