ngx-treeview
An Angular treeview component with checkbox
Dependencies
You can customize CSS yourself to break down dependencies to Bootstrap & Font Awesome.
Features
-
TreeviewConfig 添加 maxCount, isShowTotal
-
maxCount 最多可以选择几项
-
isShowTotal 选中显示结果样式类型
-
将默认 checked 为选中状态改为 不选中
-
将默认项为 checked = true 改为 false
-
Unlimited tree level
-
State: disabled / collapse, expand
-
Filtering
-
Internationalization (i18n) support
-
Template
Installation
After install the above dependencies, install ngx-treeview
via:
npm install --save mizi-ngx-treeview
Once installed you need to import our main module in your application module:
; @
Usage
Treeview:
Treeview with dropdown:
config
is optional. This is the default configuration:
isShowAllCheckBox: true isShowFilter: false isShowCollapseExpand: false maxHeight: 500 maxCount: 0 isShowTotal: true
You can change default configuration easily because TreeviewConfig is injectable.
ngxTreeview
:
Pipe To map your JSON objects to TreeItem objects.
Create a TreeviewItem:
const itCategory = text: 'IT' value: 9 children: text: 'Programming' value: 91 children: text: 'Frontend' value: 911 children: text: 'Angular 1' value: 9111 text: 'Angular 2' value: 9112 text: 'ReactJS' value: 9113 text: 'Backend' value: 912 children: text: 'C#' value: 9121 text: 'Java' value: 9122 text: 'Python' value: 9123 checked: false text: 'Networking' value: 92 children: text: 'Internet' value: 921 text: 'Security' value: 922 ;
You can pass the second paramater 'autoCorrectChecked' with value=true (default is false) in constructor of TreeviewItem to correct checked value of it and all of its descendants. In some cases, you need to push or pop children flexibly, checked of parent may be not correct. Then you need to call function correctChecked() to help to correct from root to its descendants.
const vegetableCategory = text: 'Vegetable' value: 2 children: text: 'Salad' value: 21 text: 'Potato' value: 22 ;vegetableCategorychildren;vegetableCategory; // need this to make 'Vegetable' node to change checked value from true to false
TreeviewEventParser:
Extract data from list of checked TreeviewItem and send it in parameter of event selectedChange. Some built-in TreeviewEventParser:
- DefaultTreeviewEventParser: return values of checked items.
- DownlineTreeviewEventParser: return list of checked items in orginal order with their ancestors.
- OrderDownlineTreeviewEventParser: return list of checked items in checked order with their ancestors. Note that: value of a leaf must be different from value of other leaves.
TreeviewItem Template:
See example 4.
Contributing
I am very appreciate for your ideas, proposals and found bugs which you can leave in github issues. Thanks in advance!