我怎样才能模仿文本溢出:Firefox中的省略号?
-
10-07-2019 - |
题
我在div中包含一些动态文本,该文本设置为用户在文本框字段中输入的内容。如果文本不适合div,那么它现在只是在边缘切断,并且所有超出边框的文本都不可见。我想截断文本,使其适合框内,并在末尾附加省略号(...)。例如:
|----div width------|
Here is some sample text that is too long.
Here is some sam...
显然在示例中它很容易,因为代码标签使用固定宽度的字体,因此它就像计算字符一样简单。我有一个可变宽度的字体,所以如果他们输入<!>“WWWWWWWWWWW <!>”;它会填充比<!>“................ <!>”更少的字符。将。
最好的方法是什么?我找到了一个简单的方法来简单地找到文本的实际像素宽度: http://www.codingforums.com/archive/index.php/t-100367.html
但即使使用这样的方法,实现省略号也有点尴尬。因此,如果它是20个字符并且我发现它不适合,我将不得不截断为19,添加省略号,然后检查它是否再次适合。然后截断为18(加上省略号)并再试一次。然后再次。再次......直到它适合。还有更好的方法吗?
编辑:我根据答案确定了我最初的方法是最好的,除了我试图通过不创建一个单独的td元素来改进上面链接中的解决方案,这只是为了测量,这感觉就像一个黑客。 / p>这是我的代码:
<div id="tab" class="tab">
<div id="tabTitle" class="tabTitle">
<div class="line1">user-supplied text will be put here</div>
<div class="line2">more user-supplied text will be put here</div>
</div>
</div>
风格:
.tab {
padding: 10px 5px 0px 10px;
margin-right: 1px;
float: left;
width: 136px;
height: 49px;
background-image: url(../images/example.gif);
background-position: left top;
background-repeat: no-repeat;
}
.tab .tabTitle {
height: 30px;
width: 122px;
overflow: hidden;
text-overflow: ellipsis;
font-size: 12px;
font-weight: bold;
color: #8B8B8B;
}
.tab .tabTitle .line1, .tab .tabTitle .line2 {
display:inline;
width:auto;
}
以及修剪并添加省略号的javascript:
function addOverflowEllipsis( containerElement, maxWidth )
{
var contents = containerElement.innerHTML;
var pixelWidth = containerElement.offsetWidth;
if(pixelWidth > maxWidth)
{
contents = contents + "…"; // ellipsis character, not "..." but "…"
}
while(pixelWidth > maxWidth)
{
contents = contents.substring(0,(contents.length - 2)) + "…";
containerElement.innerHTML = contents;
pixelWidth = containerElement.offsetWidth;
}
}
<!> quot; line1 <!> quot;和<!> quot; line2 <!> quot; div传递给函数。它适用于单个字输入的情况,如<!>“WWWWWWWWWWWWWWWWWW <!>但不能使用多字输入<!> WWWWW WWWWW WWWWW <!>因为它只是添加换行符并将文本测量为<!>“WWWWW <!>”的宽度。
有没有办法解决这个问题,而无需将文本复制到隐藏的测量元素中?某种方法来设置行div的样式,以便它们不包装文本?
解决方案
设置行div的样式以便它们不包装文本的某种方式?
你有white-space: nowrap
。是的,这也适用于古老的浏览器。
其他提示
此问题也必须适用于Firefox。
HTML
<div class="ellipsis">Here goes too long text and when it is takes more than 200px in "end" of the text appears "..."</div>
CSS
.ellipsis{
width:200px;
text-overflow:ellipsis;
-o-text-overflow:ellipsis;
-moz-binding:url('bindings.xml#ellipsis');//issue for Firefox
}
bindings.xml
<bindings xmlns="http://www.mozilla.org/xbl" xmlns:xul="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
<binding id="none">
<content><children/></content>
</binding>
<binding id="ellipsis">
<content>
<xul:label crop="end"><children/></xul:label>
</content>
<implementation>
<field name="label">document.getAnonymousNodes(this)[0]</field>
<field name="style">this.label.style</field>
<property name="display">
<getter>this.style.display</getter>
<setter>if(this.style.display!= val)this.style.display=val</setter>
</property>
<property name="value">
<getter>this.label.value</getter>
<setter>if(this.label.value!=val)this.label.value=val</setter>
</property>
<method name="update">
<body>
var strings= this.textContent.split(/\s+/g)
if(!strings[0])strings.shift()
if(!strings[strings.length-1])strings.pop()
this.value=strings.join('')
this.display=strings.length?'':'none'
</body>
</method>
<constructor>this.update()</constructor>
</implementation>
<handlers>
<handler event="DOMSubtreeModified">this.update()</handler>
</handlers>
</binding>
</bindings>
如果您正在使用jQuery,我使用的是精彩插件。
或者,[这个例子](404 NOT FOUND!)似乎可以跨浏览器工作。
有任何问题,请在评论中打我!
404链接: http://www.hedgerwow.com/360/ DHTML / text_overflow / demo2.php
新版本的CSS(CSS3)应该包含text-overflow:ellipsis
,它会为您完成此操作。它目前适用于IE版本6及更高版本,以及Safari和Chrome。 Firefox不支持它,所以这还不是一个真正有用的答案,但值得记住的是,真正最好的方法最终是让CSS处理这个问题。
CSS3规范草案: http: //www.w3.org/TR/2001/WD-css3-text-20010517/#text-overflow-props
支持的浏览器: http://www.quirksmode.org/css/contents.html (向下滚动到<!>“;文本溢出<!>”;靠近底部)
很简单,不,没有更好的办法,不诉诸黑客。
例如,你可以使用一个位置:绝对跨度来定位<!>“; ...... <!>”;在实际内容之上,在容器上使用overflow:hidden设置,并且只有在内容适合容器内时才隐藏额外的span。这让你只运行一次截断代码。就个人而言,我只需要多次运行像素宽度计算。设置文本和读取宽度是一个快速的操作,因此它不应该是显而易见的。
使用text-overflow:ellipsis
。它不仅仅是IE ......大多数主流浏览器都可以做到这一点
但如果你不能这里是一个jQuery插件。
只回答你提出的一点:
所以,如果它是20个字符,我发现 它不适合,我必须 截断为19,添加省略号,和 然后检查它是否再次适合。然后 截断为18(加上省略号)和 再试一次。然后再次。和 再次...直到它适合。有没有 更好的方法?
找到正确长度的更快的方法是将字符串切成两半,测试它是否适合。如果是这样的话:重新加上原始长度的四分之一,如果它没有减掉四分之一,那么测试它是否适合。以原始长度的1/8,1 / 16,1 / 32,...递归重复,直到此加/减值小于1.
这是一种搜索算法:对于长度超过几个字的字符串,通常可以将需要在DOM中执行的测试数量减少10倍。
试试这个:
更新
如果使用专有的{word-wrap:break-word;},IE将强制换行。现代浏览器可能具有默认的{overflow:visible;},并且它们会正常溢出,而不会扩展容器。
不,这不是一项简单的任务。我不得不在一年前做同样的事情,发现甚至Internet Explorer(从版本6),Opera和Safari都可以做到,但没有Firefox。很抱歉,只有黑客才能救你
使用Opera:
-o-text-overflow:ellipsis;
我从 Binyamin 的回复中将this.value=strings.join('')
更改为this.value=strings.join(' ')
,这对我很有用!