博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
网页内连续英文或符号时 强制折行与不折行的解决方案
阅读量:6266 次
发布时间:2019-06-22

本文共 4869 字,大约阅读时间需要 16 分钟。

关键词
   
   
   
   
                                          

网页开发过程中时常会遇到关于折行和不折行的问题。

比如连续英文或符号时,即使定义了宽度,文本还是没法折行,因为没有字符、字母里间隔的话,会当成一个单词。所以按不能折行来解析。
这时如果遇到了链接url,往往全是连续的英文和字母,这样就会把原本做好的页面搅乱。
而有的时候,我们希望强制不折行,或者某一链接不折行,或者折行时链接一起折行,而不会出现链接里两个字有断开的折行。
首先做个需要折行的效果,如果遇到连续的英文字母符号时,当窗口缩小时看下是否折行。
<br>
<hr>
什么也不加,不折行
<div style="width:200px;height:50px">
</div>
<br>
<hr>
加上 word-break:break-all;word-wrap:break-word;在IE下缩小窗口时候折行,但firefox不折行.
<div style="width:200px;height:50px;word-break:break-all;word-wrap:break-word;">
</div>
<br>
<hr>
加上 word-break:break-all;word-wrap:break-word;overflow:hidden;在IE下缩小窗口时候折行,但firefox不折行.
<div style="width:200px;height:50px;word-break:break-all;word-wrap:break-word;overflow:hidden;">
</div>
<hr>
若firefox下也要把英文url强制折行,需要增加js
如下:
<pre>
<script language="javascript" type="text/javascript" defer="defer">
javascript:(function(){var D=document; F(D.body); function F(n){var u,r,c,x; if(n.nodeType==3){ u=n.data.search(/\S{10}/); if(u>=0) { r=n.splitText(u+10); n.parentNode.insertBefore(D.createElement("WBR"),r); } }else if(n.tagName!="STYLE" && n.tagName!="SCRIPT"){for (c=0;x=n.childNodes[c];++c){F(x);}} } })();
</script>
</pre>

如果不增加js可以参考如下:

在其它浏览器中要实现文字自动强制折行功能,代码如下。

pre{

white-space: pre; /* CSS2 */
white-space: -moz-pre-wrap; /* Mozilla */
white-space: -hp-pre-wrap; /* HP printers */
white-space: -o-pre-wrap; /* Opera 7 */
white-space: -pre-wrap; /* Opera 4-6 */
white-space: pre-wrap; /* CSS 2.1 */
white-space: pre-line; /* CSS 3 (and 2.1 as well, actually) */
word-wrap: break-word; /* IE */
}
word-wrap和white-space都可以控制,但对IE5就不起作用了。
在IE5下面控制元素折行应该使用这个 word-break : normal | break-all | keep-all 
<br>
<br>
强制不折行
对于table来讲,给td增加nowrap就行。xhtml写法是nowrap="nowrap";
用style="white-space:nowrap;"同样可以强制不折行。或者用<nobr>来包括不允许折行的内容。<hr>
<div  style="width:200px;height:50px;white-space:nowrap;">
强制不折行强 制fasdf不折 行强制不折行强制fasf不 折行强制 不折行fasfsa强制不折行
</div>
<hr>
<br>
<div  style="width:200px;height:50px;">
<nobr>
强制不 折行fasd强制 不折行强制不fasdf折行强制不折行 强制不折行fasdf强制不折行
</nobr>
</div>
<br><br><hr>
<br>


有样式控制

fadsfdasfdasdgaggagadgagagagfadsfdasfdasdgaggagadgagagag 中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
有样式控制word-break:break-all
fadsfdasfdasdgaggagadgagagagfadsfdasfdasdgaggagadgagagag 中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
有样式控制word-break:break-all;word-wrap:break-word
fadsfdasfdasdgaggagadgagagagfadsfdasfdasdgaggagadgagagag 中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
有样式控制word-break:break-all;word-wrap:break-word

fadsfdasfdasdgaggagadgagagagfadsfdasfdasdgaggagadgagagag 中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。


给table加样式 style="table-layout:fixed;width:300px;color:red;background-color:#cecece;word-break:break-all;word-wrap:break-word"

fadsfdasfdasdgaggagadgagagagfadsfdasfdasdgaggagadgagagag 中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

给td加样式 style="table-layout:fixed;width:300px;color:red;background-color:#cecece;word-break:break-all;word-wrap:break-word"

fadsfdasfdasdgaggagadgagagagfadsfdasfdasdgaggagadgagagag 中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国中国。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

转载:


css之自动换行 


大家都知道连续的英文或数字能是容器被撑大,不能根据容器的大小自动换行,下面是 CSS如何将他们换行的方法! 

对于div 

1.(IE浏览器)white-space:normal; word-break:break-all;这里前者是遵循标准。

       #wrap{white-space:normal; width:200px; }

或者

       #wrap{word-break:break-all;width:200px;}

<div id="wrap">ddd1111111111111111111111111111111111</div>

效果:可以实现换行 

2.(Firefox浏览器)white-space:normal; word-break:break-all;overflow:hidden;同样的FF下也没有很好的实现方法,只能隐藏或者加滚动条,当然不加滚动条效果更好! 

       #wrap{white-space:normal; width:200px; overflow:auto;}

或者

       #wrap{word-break:break-all;width:200px; overflow:auto; }

       <div id="wrap">ddd1111111111111111111111111111111111111111</div>

效果:容器正常,内容隐藏 

对于table 

1. (IE浏览器)使用样式table-layout:fixed; 

       <style>

       .tb{table-layout:fixed}

       </style>

       <table class="tbl" width="80">

       <tr>

       <td>abcdefghigklmnopqrstuvwxyz 1234567890

       </td>

       </tr>

       </table>

效果:可以换行 

2.(IE浏览器)使用样式table-layout:fixed与nowrap 

       <style>

       .tb {table-layout:fixed}

       </style>

       <table class="tb" width="80">

       <tr>

       <td nowrap>abcdefghigklmnopqrstuvwxyz 1234567890

       </td>

       </tr>

       </table>

效果:可以换行 

3. (IE浏览器)在使用百分比固定td大小情况下使用样式table-layout:fixed与nowrap 

       <style>

       .tb{table-layout:fixed}

       </style>

       <table class="tb" width=80>

       <tr>

       <td width=25% nowrap>abcdefghigklmnopqrstuvwxyz 1234567890

       </td>

       <td nowrap>abcdefghigklmnopqrstuvwxyz 1234567890

       </td>

       </tr>

       </table>

效果:两个td均正常换行 

3.(Firefox浏览器)在使用百分比固定td大小情况下使用样式table-layout:fixed与nowrap,并且使用div 

       <style>

       .tb {table-layout:fixed}

       .td {overflow:hidden;}

       </style>

       <table class=tb width=80>

       <tr>

       <td width=25% class=td nowrap>

       <div>abcdefghigklmnopqrstuvwxyz 1234567890</div>

       </td>

       <td class=td nowrap>

       <div>abcdefghigklmnopqrstuvwxyz 1234567890</div>

       </td>

       </tr>

       </table>

这里单元格宽度一定要用百分比定义 

效果:正常显示,但不能换行(注:在FF下还没有能使容器内容换行的好方法,只能用overflow将多出的内容隐藏,以免影响整体效果)

转载于:https://www.cnblogs.com/ylemzhang/archive/2012/01/18/2325669.html

你可能感兴趣的文章
Java8新特性之二:方法引用
查看>>
记录日常Linux常用软件
查看>>
Jmeter之Bean shell使用(一)
查看>>
[翻译]利用顶点位移的VR畸变校正
查看>>
wp socket tcp链接
查看>>
asp.net 批量下载实现(打包压缩下载)
查看>>
解决了!我滴神哪!MarketPlace为什么手动下载安装部署提示invalid详解
查看>>
主成分分析原理及推导
查看>>
python中获取指定目录下所有文件名列表的程序
查看>>
HTML5的本地存储 LocalStorage
查看>>
safari和ie的时间解析(显示为NAN)
查看>>
基于 HTML5 WebGL 的挖掘机 3D 可视化应用
查看>>
Java工具创建密钥库,用于Unity 3D打包、签名、发布
查看>>
Oracle用户解锁
查看>>
MongoDB的使用
查看>>
C#开启异步 线程的四种方式
查看>>
XML解析
查看>>
2784: 【提高】小 X 与煎饼达人(flip)
查看>>
Linux 常用的压缩命令有 gzip 和 zip
查看>>
内存分段与分页
查看>>