文本溢出始终是一个大问题,尤其是在程序化环境中。总是只有这么多的空间,但可变的内容可以添加到该空间。我最近在一个用于显示用户信息的表上工作,并注意到更长的字符串打破了表格显示。显而易见的解决方案是overflow: hidden为表格单元格添加一个设置,但即使这样,文本看起来也不自然地被切断了。使文本溢出优雅的方法是使用省略号和CSS'文本溢出属性。让我们来看看!
CSS
创建省略号后面的CSS非常简单,包括宽度,包装,溢出和文本溢出:
.dataTable td { / * essential * / text-overflow :ellipsis ; width: 200px ; white-space: nowrap ; overflow:hidden ; / *外观漂亮* / padding: 10px; }
设置宽度提供明显的边界,白色空间阻止正常的下一行换行,隐藏溢出确保宽度维度得到遵守,文本溢出设置提供省略号。太棒了吧?但是有一个问题......
Firefox和省略号
不幸的是,Firefox目前不支持文本溢出:省略号。Dojo Toolkit为Firefox提供了一个简单的解决方案: dojox.html.ellipsis。此资源使用iFrame填充程序来创建省略号。以下是如何使用它:
//需要资源 dojo 。require (“dojox.html.ellipsis” );
在需要JavaScript资源之后,是时候dojoxEllipsis在页面中放置一个节点,表明dojox.html.ellipsis资源应该对它进行椭圆化:
< div class = “ dojoxEllpsis ” > Pellentesque居住者morbi tristique senectus et netus et malesuada ... </ div >
dojoxEllipsis每次修改DOM树时,Dojo都会在页面中搜索具有CSS类的元素并对其进行椭圆化处理。
为内容实现动态省略号是一种简单,微妙且有效的方式,可以在受限制的内容中优雅地管理内容。除了Firefox之外,文本溢出:主要浏览器供应商支持省略号。Dojo的实现是稳定且有效的,但如果页面上有许多椭圆化元素,则会降低页面的速度。快乐的椭圆化!
以上是使用CSS解决文本溢出的方法的详细内容。更多信息请关注PHP中文网其他相关文章!