我需要构建一个javascript函数,在我选择一个子元素时自动选择父元素。例如,我有一个有3个孩子的父母,一旦我点击一个孩子,也应该选择父母,并向上冒泡直到根。当我取消点击孩子时我应该取消选中所有父母的相同逻辑。 我在哪里可以找到这种逻辑?
答案 0 :(得分:0)
假设:
<ul>
<li>Parent
<ul>
<li>Child 1</li>
<li>Child 2</li>
<li>Child 3</li>
</ul>
</li>
</ul>
您可以这样做:
$('li li').click(function () {
$(this).css('background-color', '#eee');
$(this).parent().css('background-color', '#eee');
});
要点击并取消点击,您可以使用.data()
标记子元素,以便跟踪点击/取消点击。希望有所帮助。
答案 1 :(得分:0)
这里有一个有效的例子。还要将jQuery添加到此示例和可以使用[]数组定义的树结构中。复选框将如您所述更改。您还可以在服务器端生成树或增强结构,以便在解析数组树时输入数据。我没有检查浏览器的兼容性。
要获取jQuery,请转到此处http://jquery.com/download/
<script type="text/javascript">
var tree =
[
[
[
[],
[]
],
[]
],
[],
[
[],
[
[],
[]
]
]
]
document.ready = function()
{
window.Cont = $("#container");
treeGen(tree, Cont);
Cont.find("input[type='checkbox']").click(checkboxClick)
}
var treeGen = function(arr, elem)
{
if (arr !== true)
for (var i = 0; i < arr.length; ++i)
{
var newElem = $("<div></div>");
$("<input type='checkbox'/>").appendTo(newElem);
newElem.appendTo(elem);
treeGen(arr[i], newElem);
}
}
var checkboxClick = function()
{
walkToRoot($(this).parent().parent(), $(this).is(":checked"))
}
var walkToRoot = function(elem, state)
{
if (elem.attr("id") != "container")
{
var cBox = elem.find("input[type='checkbox']").first();
cBox.get(0).checked = state;
walkToRoot(elem.parent(), state);
}
}
</script>
<style>
#container div
{
margin-left:50px;
margin-bottom:4px;
}
</style>
<div id="container"></div>
答案 2 :(得分:0)
解决方案取决于您构建树视图的方式。 假设以下HTML:
<ul>
<li>
<input type="checkbox">A</input>
<ul>
<li>
<input type="checkbox" />Once</input>
<ul>
<li><input type="checkbox">One</input></li>
<li><input type="checkbox">Two</input></li>
<li><input type="checkbox">Three</input></li>
</ul>
</li>
<li><input type="checkbox">Two</input></li>
<li>
<input type="checkbox">Three</input>
<ul>
<li><input type="checkbox">One</input></li>
<li><input type="checkbox">Two</input></li>
<li><input type="checkbox">Three</input></li>
</ul>
</li>
</ul>
</li>
<li>
<input type="checkbox">B</input>
<ul>
<li><input type="checkbox">One</input></li>
<li><input type="checkbox">Two</input></li>
<li><input type="checkbox">Three</input></li>
</ul>
</li>
</ul>
您可以使用JQuery选择器实现它:
$('li :checkbox').change(function() {
var $parent = $(this).parents().eq(2);
$parent.children('li :checkbox')
.prop('checked', $parent.find('li :checkbox:checked').size() > 0)
.change();
});
以下是小提琴的链接 - http://jsfiddle.net/xEbPn/1/