これは小さな問題だと思いますが、どういうわけか立ち往生しています。
次のコードを検討してください
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;
}
ジャバスクリプト:
/* Case 1: No of char inside div when hidden elements are removed
RETURNS 53 */
$('div.india').find(":hidden").remove();
alert($('div.india').text().length);
ここで、非表示の要素を削除せずに同じ長さ (=53) を返したいと考えています。次のことを試しました(1つずつ/または別の同様の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);