TreeView与复选框

时间:2013-09-19 16:25:18

标签: javascript

我需要构建一个javascript函数,在我选择一个子元素时自动选择父元素。例如,我有一个有3个孩子的父母,一旦我点击一个孩子,也应该选择父母,并向上冒泡直到根。当我取消点击孩子时我应该取消选中所有父母的相同逻辑。 我在哪里可以找到这种逻辑?

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/