今天在工做的時候,遇到了一個需求,就是須要一鍵展開或者關閉樹形結構。關於樹形結構的不是很熟悉,而後去百度,結果也不是很準確。最後通過Google才找到。下面分享給你們javascript
直接看代碼:html
1 var flag = true;//開啓仍是關閉的標誌位 2 function change_tree(target){ 3 if(flag){ 4 //$table.treegrid('getRootNodes').treegrid('expand'); 5 //$table.treegrid('getParentNode').treegrid('expand'); 6 $table.treegrid('expandAll'); 7 flag = !flag; 8 }else{ 9 //$table.treegrid('getRootNodes').treegrid('collapse'); 10 //$table.treegrid('getParentNode').treegrid('collapse'); 11 $table.treegrid('collapseAll'); 12 flag = !flag; 13 } 14 }
上面的是摺疊,下面的是展開。有一個標誌位,每次執行不一樣的代碼。而後把找到的表格貼在下面,方便你們查閱(侵刪)java
經常使用的配置項,這個表格能夠和我上一篇的一塊兒看node
參數 | 類型 | 默認值 | 描述 |
treeColumn | Numeric | 0 | 樹中表格中的哪一列 |
initialState | String | expanded | 初始化時樹的狀態 'expanded' - 全部節點都展開 'collapsed' - 全部節點都摺疊 |
saveState | Boolean | false | 若是是true樹的再次加載頁面的時候樹的狀態將保存 |
saveStateMethod | String | cookie | 'cookie' - 保存cookie的狀態 'hash' - 保存hash的狀態 |
saveStateName | String | tree-grid-state | 經過cookie或hash的名字來保存狀態 |
expanderTemplate | String | <span class="treegrid-expander"></span> | 點擊HTML元素時將摺疊或展開分支 |
expanderExpandedClass | String | treegrid-expander-expanded | 當它展開的時候能夠使用擴展元素 |
expanderCollapsedClass | String | treegrid-expander-collapsed | 當它摺疊的時候能夠使用擴展元素 |
indentTemplate | String | <span class="treegrid-indent"></span> | HTML元素將根據深度嵌套節點作填充 |
而後下面是重頭戲了,就是咱們經常使用到的一些方法,都是有分封裝的。你們能夠自行取用cookie
方法名稱 | 描述 | 示例 |
getRootNodes | 返回樹的根節點 |
|
getNodeId | 返回節點的id | if($('#node-2').treegrid('getNodeId')===2){ // Do something with node 2 }; |
getParentNodeId | 返回父節點的id或若是節點是根就返回null | if($('#node-2').treegrid('getParentNodeId')===2){ // Do something if parent node Id is 2 }; |
getAllNodes | 返回樹的全部節點 | // Find all nodes $('#tree-1').treegrid('getAllNodes').each(function() { if ($(this).treegrid("isLast")) { //Do something with all last nodes } }); |
getParentNode | 返回父節點或若是節點是根就返回null | // Expand parent node $('#node-2').treegrid('getParentNode').treegrid('collapse'); |
getChildNodes | 返回節點的子節點或若是節點是葉子節點則返回null | // Expand child nodes $('#node-2').treegrid('getChildNodes').treegrid('expand'); |
getDepth | 返回樹嵌套分支的深度 | // Expand all nodes 2nd nesting $('.tree').find('tr').each(function(){ if ($(this).treegrid('getDepth')<2){ $(this).treegrid('expand'); } }); |
isNode | 若是元素是節點則返回true | $('#tree-1').find('tr').each(function() { if ($(this).treegrid("isNode")) { //Do something } }); |
isLeaf | 該節點有葉子嗎 | // hide all files $('.tree').find('tr').each(function(){ if ($(this).treegrid('isLeaf')){ $(this).hide(); } }); |
isLast | 若是節點在最後,則返回true | // hide all last elements $('.tree').find('tr').each(function(){ if ($(this).treegrid('isLast')){ $(this).hide(); } }); |
isFirst | 若是節點在第一個,則返回true | // hide all last elements $('.tree').find('tr').each(function(){ if ($(this).treegrid('isFirst')){ $(this).hide(); } }); |
isExpanded | 節點是展開的嗎 | if($('#node-2').treegrid('isExpanded')){ // Do something if node expanded }; |
isCollapsed | 節點是摺疊的嗎 | if($('#node-2').treegrid('isCollapsed')){ // Do something if node collapsed }; |
isOneOfParentsCollapsed | 至少一個節點是摺疊的嗎 | if($('#node-2').treegrid('isOneOfParentCollapsed')){ // Do something if one of parent collapsed }; |
expand | 展開節點 | $('#node-2').treegrid('expand'); |
collapse | 摺疊節點 | $('#node-2').treegrid('collapse'); |
expandRecursive | 節點遞歸展開 | $('#node-2').treegrid('expandRecursive'); |
collapseRecursive | 節點遞歸摺疊 | $('#node-2').treegrid('collapseRecursive'); |
expandAll | 展開全部節點 | $('#tree').treegrid('expandAll'); |
collapseAll | 摺疊全部節點 | $('#tree').treegrid('collapseAll'); |
toggle | 當處於展開狀態的時候將節點摺疊 當處於摺疊狀態的時候將節點展開 |
$('#node-2').treegrid('toggle'); |
render | 重繪節點及其子節點 | $('#node-2').treegrid('render'); |