我嵌套了无序列表,列表项的标题看起来像这样。
<ul>
<li><input type="checkbox" /> Header 1</li>
<ul>
<li><input type="checkbox" value="1" />Item 1</li>
</ul>
<li><input type="checkbox" /> Header 2</li>
<ul>
<li><input type="checkbox" value="1" />Item 1</li>
<li><input type="checkbox" value="2" />Item 2</li>
<li><input type="checkbox" value="3" />Item 3</li>
<li><input type="checkbox" value="4" />Item 4</li>
</ul>
<li><input type="checkbox" /> Header 3</li>
<ul>
<li><input type="checkbox" value="5" />Item 5</li>
<li><input type="checkbox" value="6" />Item 6</li>
<li><input type="checkbox" value="7" />Item 7</li>
<li><input type="checkbox" value="8" />Item 8</li>
<li><input type="checkbox" value="9" />Item 9</li>
<li><input type="checkbox" value="10" />Item 10</li>
<li><input type="checkbox" value="11" />Item 11</li>
<li><input type="checkbox" value="12" />Item 12</li>
<li><input type="checkbox" value="13" />Item 13</li>
<li><input type="checkbox" value="14" />Item 14</li>
<li><input type="checkbox" value="15" />Item 15</li>
<li><input type="checkbox" value="16" />Item 16</li>
</ul>
</ul>
请注意,项目 1 位于 Header 1 的列表和 Header 2 的列表中。
我正在努力完成一些事情。
- 当我单击标题项时,它将自动选择或取消选择
li
其ul
列表中紧随其后的所有列表项。 - 当我单击
li
嵌套中的列表项时,ul
我想检查其他项是否全部选中(在这种情况下,在标题列表项上放置复选标记)或未选中(在这种情况下,删除复选标记标题列表项)如果它是选中和未选中的混合,则将标题列表项设置为不确定状态。 - 当我检查一个列表项时,例如显示在标题 1 的列表和标题 2 的列表中的列表项 1,我希望它取消选中这两个项目,或者检查两个列表中的两个项目,并导致检查要求 2在受影响的名单上。
我真的很难做到这一点,因为我并不是很擅长 JavaScript,而且到目前为止我读过的所有代码都没有真正接近我的需要。
任何帮助,将不胜感激。我使用的是 jQuery 1.9.1,但如果你想用最基本的 JavaScript 来做这件事,我也可以(因为当你在 Google 开发工具中设置一个刹车点以查看发生了什么时,它更容易遵循)。