2009-09-17 117 views
3

我有幾個父節點。每個父節點都包含一個子節點列表。我的showcheckboxes設置爲全部。asp.net treeview複選框選擇

我的問題:

在客戶端,當我檢查父節點 - 我怎麼能檢查所有的子節點而不做回發或使用AJAX。

問候

+0

JavaScript是好嗎? – manji 2009-09-17 09:07:30

回答

19
tv.Attributes.Add("onclick", "OnTreeClick(event)"); 

添加這段JavaScript代碼

<script language="javascript" type="text/javascript"> 
    function OnTreeClick(evt) { 
     var src = window.event != window.undefined ? window.event.srcElement : evt.target; 
     var isChkBoxClick = (src.tagName.toLowerCase() == "input" && src.type == "checkbox"); 
     if (isChkBoxClick) { 
      var parentTable = GetParentByTagName("table", src); 
      var nxtSibling = parentTable.nextSibling; 
      if (nxtSibling && nxtSibling.nodeType == 1)//check if nxt sibling is not null & is an element node 
      { 
       if (nxtSibling.tagName.toLowerCase() == "div") //if node has children 
       { 
        //check or uncheck children at all levels 
        CheckUncheckChildren(parentTable.nextSibling, src.checked); 
       } 
      } 
      //check or uncheck parents at all levels 
      CheckUncheckParents(src, src.checked); 
     } 
    } 

    function CheckUncheckChildren(childContainer, check) { 
     var childChkBoxes = childContainer.getElementsByTagName("input"); 
     var childChkBoxCount = childChkBoxes.length; 
     for (var i = 0; i < childChkBoxCount; i++) { 
      childChkBoxes[i].checked = check; 
     } 
    } 

    function CheckUncheckParents(srcChild, check) { 
     var parentDiv = GetParentByTagName("div", srcChild); 
     var parentNodeTable = parentDiv.previousSibling; 

     if (parentNodeTable) { 
      var checkUncheckSwitch; 

      if (check) //checkbox checked 
      { 
       var isAllSiblingsChecked = AreAllSiblingsChecked(srcChild); 
       if (isAllSiblingsChecked) 
        checkUncheckSwitch = true; 
       else 
        return; //do not need to check parent if any(one or more) child not checked 
      } 
      else //checkbox unchecked 
      { 
       checkUncheckSwitch = false; 
      } 

      var inpElemsInParentTable = parentNodeTable.getElementsByTagName("input"); 
      if (inpElemsInParentTable.length > 0) { 
       var parentNodeChkBox = inpElemsInParentTable[0]; 
       parentNodeChkBox.checked = checkUncheckSwitch; 
       //do the same recursively 
       CheckUncheckParents(parentNodeChkBox, checkUncheckSwitch); 
      } 
     } 
    } 

    function AreAllSiblingsChecked(chkBox) { 
     var parentDiv = GetParentByTagName("div", chkBox); 
     var childCount = parentDiv.childNodes.length; 
     for (var i = 0; i < childCount; i++) { 
      if (parentDiv.childNodes[i].nodeType == 1) //check if the child node is an element node 
      { 
       if (parentDiv.childNodes[i].tagName.toLowerCase() == "table") { 
        var prevChkBox = parentDiv.childNodes[i].getElementsByTagName("input")[0]; 
        //if any of sibling nodes are not checked, return false 
        if (!prevChkBox.checked) { 
         return false; 
        } 
       } 
      } 
     } 
     return true; 
    } 

    //utility function to get the container of an element by tagname 
    function GetParentByTagName(parentTagName, childElementObj) { 
     var parent = childElementObj.parentNode; 
     while (parent.tagName.toLowerCase() != parentTagName.toLowerCase()) { 
      parent = parent.parentNode; 
     } 
     return parent; 
    } 

</script> 
+0

不適合我。我的樹視圖在modelpopupextender中。這是個問題嗎 ??? – 2014-02-25 04:34:25

+0

感謝朋友。這是100%的工作。 – Sylar 2015-05-24 17:54:15

8

的最佳解決方案上面,非常感謝。 我將方法CheckUncheckParents()更改爲我的偏好設置:當選中其中一個子節點時,父節點也將被檢查。

function OnTreeClick(evt) { 
    var src = window.event != window.undefined ? window.event.srcElement : evt.target 
    var isChkBoxClick = (src.tagName.toLowerCase() == "input" && src.type == "checkbox"); 
    if (isChkBoxClick) { 
     var parentTable = GetParentByTagName("table", src); 
     var nxtSibling = parentTable.nextSibling; 
     if (nxtSibling && nxtSibling.nodeType == 1)//check if nxt sibling is not null & is an element node 
     { 
      if (nxtSibling.tagName.toLowerCase() == "div") //if node has children 
      { 
       //check or uncheck children at all levels 
       CheckUncheckChildren(parentTable.nextSibling, src.checked); 
      } 
     } 
     //check or uncheck parents at all levels 
     CheckUncheckParents(src, src.checked); 
    } 
} 

function CheckUncheckChildren(childContainer, check) { 
    var childChkBoxes = childContainer.getElementsByTagName("input"); 
    var childChkBoxCount = childChkBoxes.length; 
    for (var i = 0; i < childChkBoxCount; i++) { 
     childChkBoxes[i].checked = check; 
    } 
} 

function CheckUncheckParents(srcChild, check) { 
    var parentDiv = GetParentByTagName("div", srcChild); 
    var parentNodeTable = parentDiv.previousSibling; 

    if (parentNodeTable) { 
     var checkUncheckSwitch; 

     if (check) //checkbox checked 
     { 
      checkUncheckSwitch = true; 
     } 
     else //checkbox unchecked 
     { 
      var isAllSiblingsUnChecked = AreAllSiblingsUnChecked(srcChild); 
      if (!isAllSiblingsUnChecked) 
       checkUncheckSwitch = true; 
      else 
       checkUncheckSwitch = false; 
     } 

     var inpElemsInParentTable = parentNodeTable.getElementsByTagName("input"); 
     if (inpElemsInParentTable.length > 0) { 
      var parentNodeChkBox = inpElemsInParentTable[0]; 
      parentNodeChkBox.checked = checkUncheckSwitch; 
      //do the same recursively 
      CheckUncheckParents(parentNodeChkBox, checkUncheckSwitch); 
     } 
    } 
} 

function AreAllSiblingsUnChecked(chkBox) { 
    var parentDiv = GetParentByTagName("div", chkBox); 
    var childCount = parentDiv.childNodes.length; 
    for (var i = 0; i < childCount; i++) { 
     if (parentDiv.childNodes[i].nodeType == 1) //check if the child node is an element node 
     { 
      if (parentDiv.childNodes[i].tagName.toLowerCase() == "table") { 
       var prevChkBox = parentDiv.childNodes[i].getElementsByTagName("input")[0]; 
       //if any of sibling nodes are not checked, return false 
       if (prevChkBox.checked) { 
        return false; 
       } 
      } 
     } 
    } 
    return true; 
} 

//utility function to get the container of an element by tagname 
function GetParentByTagName(parentTagName, childElementObj) { 
    var parent = childElementObj.parentNode; 
    while (parent.tagName.toLowerCase() != parentTagName.toLowerCase()) { 
     parent = parent.parentNode; 
    } 
    return parent; 
} 
+0

謝謝你,這是一個古老的線索,但只是幫助我極大! – bgs264 2013-01-30 14:28:31

+0

在Firefox中不適用於我。我已經爲您提供了相同的代碼 – 2014-02-24 09:57:47

+0

此代碼適用於除我以外的所有人。可能是什麼問題。我在modelpopupextender控件中顯示了treeview。它是錯誤的 – 2014-02-24 10:20:17

1

由於我在問題中的問題完全相同,所以必須更改解決方案以僅影響子節點。

<script language="javascript" type="text/javascript"> 
function OnTreeClick(evt) { 
    var src = window.event != window.undefined ? window.event.srcElement : evt.target; 
    var isChkBoxClick = (src.tagName.toLowerCase() == "input" && src.type == "checkbox"); 
    if (isChkBoxClick) { 
     var parentTable = GetParentByTagName("table", src); 
     var nxtSibling = parentTable.nextSibling; 
     if (nxtSibling && nxtSibling.nodeType == 1)//check if nxt sibling is not null & is an element node 
     { 
      if (nxtSibling.tagName.toLowerCase() == "div") //if node has children 
      { 
       //check or uncheck children at all levels 
       CheckUncheckChildren(parentTable.nextSibling, src.checked); 
      } 
     } 
     //check or uncheck parents at all levels 
     //CheckUncheckParents(src, src.checked); 
    } 
} 

function CheckUncheckChildren(childContainer, check) { 
    var childChkBoxes = childContainer.getElementsByTagName("input"); 
    var childChkBoxCount = childChkBoxes.length; 
    for (var i = 0; i < childChkBoxCount; i++) { 
     childChkBoxes[i].checked = check; 
    } 
} 


//utility function to get the container of an element by tagname 
function GetParentByTagName(parentTagName, childElementObj) { 
    var parent = childElementObj.parentNode; 
    while (parent.tagName.toLowerCase() != parentTagName.toLowerCase()) { 
     parent = parent.parentNode; 
    } 
    return parent; 
} 

+0

不工作在Firefox – 2014-02-24 10:00:37

0
private void CheckUnCheck(object sender) 
     { 
      if ((sender as TreeView).SelectedNode.Checked == true) 
       foreach (TreeNode tr in (sender as TreeView).SelectedNode.ChildNodes) 
       { 
        foreach (TreeNode child in tr.ChildNodes) 
         child.Checked = true; 
        tr.Checked = true; 
       } 
      else 
       foreach (TreeNode tr in (sender as TreeView).SelectedNode.ChildNodes) 
       { 
        foreach (TreeNode child in tr.ChildNodes) 
         child.Checked = false; 
        tr.Checked = false; 
       } 
     }