編集:選択した回答に基づく私の解決策:
var $brs,
$chunks = [];
$brs = $('hr:eq(1)').nextUntil($('hr:eq(2)')).filter('br');
$chunks.push($('hr:eq(1)').nextUntil($brs.eq(0)));
for (i = 0; i < $brs.length - 1; i++) {
$chunks.push($brs.eq(i).nextUntil($brs.eq(i+1)));
}
私は、javascript で解析しようとしている非常に貧弱に書かれた Web サイトに起因する異常なケースを持っています。楽しい構文解析については詳しく説明しませんが、最終的に意味のある構造に分解することができました。これで、次のような DOM ができました (すべての意図と目的のために、これをタグのフラットなリストとして見てください。それぞれが次の開始前に閉じられます)。
<hr>
<a>
<span class="desc">
[<a>*] // 0 or more anchor tags can show up here
<br>
<br>
<a>
<span class="desc">
[<a>*]
<br>
<br>
.
.
.
私がやろうとしているのは、本質的に <br> タグで .split() を実行することにより、タグの各クラスターを独自の配列/jquery オブジェクト/何でも取得することです。そのようなことは可能ですか?そうでない場合、これをどのようにチャンクに分割しますか? したがって、結果は次のようになります。
[<a>, <span class="desc">, <a>],
[<a>, <span class="desc">],
[<a>, <span class="desc">, <a>, <a>, <a>],
[<a>, <span class="desc">],
...