我认为这是一个小问题,但我卡住,不知何故。计算jQuery文本()。可见元素的长度而不删除隐藏元素
考虑下面的代码
HTML:
<div class="india">
<p class="hidden"> Uttar Pradesh </p>
<p> Andhra Pradesh </p>
<p class="hidden"> Uttar Pradesh </p>
<p> Andhra Pradesh </p>
</div>
CSS:
.hidden{
display: none;
}
JAVASCRIPT:
/* Case 1: No of char inside div when hidden elements are removed
RETURNS 53 */
$('div.india').find(":hidden").remove();
alert($('div.india').text().length);
现在我想回到山姆e长度(= 53)而不移除隐藏的元素。我曾尝试做以下事情(一个接一个/或单独类似的div),但它们都返回不同的长度
如何在不移除隐藏元素的情况下返回相同的长度?解释为什么他们是不同的长度欢迎!
链接:http://jsfiddle.net/deveshz/R2QNM/1/
// Without Removing hidden div RETURNS 32
/*Case 2: */
alert($('div.india').find(":visible").text().length);
/* Case 3 */
var charlength = 0;
$('div.india').find(":visible").each(function(){
charlength += $(this).text().length;
});
alert(charlength);
/*Case 4 RETURNS 21*/
var clone = $('div.india').clone();
clone.find(":hidden").remove();
alert(clone.text().length);
看起来像第一个长度调用包含空格和可能的回车。 'alert($('div.india')。find(“:visible”)。text()。length);'犯规。尝试提醒长度警报之前的实际文字,你会看到区别 –