[英]How to make Treeview check only one option
我有一個Treeview,並且Checkbox設置為true。 我想要的是在整個樹視圖中僅選中一個復選框。 我怎樣才能做到這一點?
僅供參考:樹形視圖的深度為三層。
最簡單的方法是為樹視圖的AfterCheck事件設置一個偶數處理程序。 在此處理程序中,您可以取消選中除已選中的節點以外的所有節點:
void node_AfterCheck(object sender, TreeViewEventArgs e) {
// only do it if the node became checked:
if (e.Node.Checked) {
// for all the nodes in the tree...
foreach (TreeNode cur_node in e.Node.TreeView.Nodes) {
// ... which are not the freshly checked one...
if (cur_node != e.Node) {
// ... uncheck them
cur_node.Checked = false;
}
}
}
}
應該工作(沒有嘗試)
盡管我提供的解決方案都無法正常工作,但這是一個古老的帖子。
所以我做了如下
private TreeNode uncheck_treeview(TreeView treeView, TreeNode treeNode, TreeViewEventHandler e)
{
treeView.AfterCheck -= e;
foreach (TreeNode node in treeView.Nodes)
{
uncheck_treenode_tree(node);
}
if (treeNode != null)
{
treeNode.Checked = true;
}
treeView.AfterCheck += e;
return treeNode;
}
和
private void uncheck_treenode(TreeNode treeNode)
{
treeNode.Checked = false;
foreach (TreeNode node in treeNode.Nodes)
{
uncheck_treenode_tree(node);
}
}
和
private void treeView1_AfterCheck(object sender, TreeViewEventArgs e)
{
var checkedNode = uncheck_treeview_tree((TreeView) sender, e.Node, treeView1_AfterCheck);
// further processing ...
}
請注意,此方法可防止StackOverflowException
!
希望對他人有用
我嘗試過它肯定有效
bool manualcheck = false;
protected override void OnAfterCheck(TreeViewEventArgs e)
{
if (manualcheck) return;
if (e.Node.Checked)
{
if (Nodes.Count>0) UnCheckAll(Nodes[0]);
manualcheck = true;
e.Node.Checked = true;
manualcheck = false;
}
}
void UnCheckAll(TreeNode node)
{
if (node != null)
{
node.Checked = false;
foreach (TreeNode item in node.Nodes)
{
manualcheck = true;
item.Checked = false;
if (item.Nodes.Count > 0) UnCheckAll(item.Nodes[0]);
}
if (node.NextNode != null)
UnCheckAll(node.NextNode);
}
manualcheck = false;
}
我遇到了同樣的問題,但是循環遍歷所有節點聽起來對性能來說是昂貴的。
這是我的解決方案,不循環所有節點,而是使用類屬性:
public partial class GuiDefault // not my whole class, just an example
{
TreeNode checkedNode = null;
private void Tree_AfterCheck(object sender, TreeViewEventArgs e)
{
TreeNode checkedNodeVar = e.Node;
if (checkedNodeVar.Checked)
{
if (checkedNode != null)
{
checkedNode.Checked = false; // set "checked" property of the last checked box to false
}
checkedNode = checkedNodeVar; // set the class property "checkedNode" to the currently checked Node
}
else
{
checkedNode = null; // if current checked box gets unchecked again, also reset the class property "checkedNode"
}
}
}
我在此解決方案中發現的唯一問題是,如果用戶將同一復選框快速切換,則該函數將無法正確調用,並且單擊兩次后便不會“單擊”或“取消選中”該框。 。
也許其他人可以添加一個修復程序,以單擊同一復選框以快速運行。
我毫不留情地偷走了這個解決方案 ,使您可以一次遍歷所有級別的所有節點。
這使得確保僅選擇一個節點變得容易:
foreach (var node in resultsTree.GetAllNodes())
{
if (node != e.Node) node.Checked = false;
}
我使用這里找到的解決方案。
頁面中的JavaScript
function client_OnTreeNodeChecked(event)
{
var treeNode = event.srcElement || event.target ;
if (treeNode.tagName == "INPUT" && treeNode.type == "checkbox")
{
if(treeNode.checked)
{
uncheckOthers(treeNode.id);
}
}
}
function uncheckOthers(id)
{
var elements = document.getElementsByTagName('input');
// loop through all input elements in form
for(var i = 0; i < elements.length; i++)
{
if(elements.item(i).type == "checkbox")
{
if(elements.item(i).id!=id)
{
elements.item(i).checked=false;
}
}
}
}
后面的代碼將client_OnTreeNodeChecked函數添加到treeviews onclick事件
private void Page_PreRender(object sender, EventArgs e)
{
TreeView1.Attributes.Add("OnClick", "client_OnTreeNodeChecked(event)");
}
注意:如果TreeView位於UpdatePanel中,請閱讀我的文章如何使javascript與Ajax UpdatePanel一起使用
<script type="text/javascript">
function MakeRadio() {
var tv = document.getElementById("<%= position_TreeView.ClientID %>");
var chkArray = tv.getElementsByTagName("input");
for (i = 0; i <= chkArray.length - 1; i++) {
if (chkArray[i].type == 'checkbox') {
chkArray[i].type = 'radio';
chkArray[i].name = 'YaMahdi';
}
}
}
window.onload = MakeRadio;
</script>
<script 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 == "radio");
if (isChkBoxClick) {
SelectOne(src.id);
}
}
function SelectOne(objId) {
var tv = document.getElementById("<%= position_TreeView.ClientID %>");
var chkArray = tv.getElementsByTagName("input");
for (i = 0; i <= chkArray.length - 1; i++) {
if (chkArray[i].type == 'radio') {
if (chkArray[i].id != objId) {
chkArray[i].checked = false;
}
}
}
}
</script>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.