TreeNode.ShowCheckBox Propriedade
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Obtém ou define um valor que indica se uma caixa de seleção é exibida ao lado do nó.
public:
property Nullable<bool> ShowCheckBox { Nullable<bool> get(); void set(Nullable<bool> value); };
public bool? ShowCheckBox { get; set; }
member this.ShowCheckBox : Nullable<bool> with get, set
Public Property ShowCheckBox As Nullable(Of Boolean)
Valor da propriedade
true
para exibir a caixa de seleção; caso contrário, false
.
Exemplos
O exemplo de código a seguir demonstra como usar a ShowCheckBox propriedade para mostrar e ocultar programaticamente a caixa de seleção de um nó no TreeView controle. Para que este exemplo funcione corretamente, você deve copiar os dados XML de exemplo abaixo para um arquivo chamado Book.xml.
<%@ Page Language="C#" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
void Data_Bound(Object sender, TreeNodeEventArgs e)
{
// Determine the depth of a node as it is bound to data.
// If the depth is 1, show a check box.
if(e.Node.Depth == 1)
{
e.Node.ShowCheckBox = true;
}
else
{
e.Node.ShowCheckBox = false;
}
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>TreeNode ShowCheckBox Example</title>
</head>
<body>
<form id="form1" runat="server">
<h3>TreeNode ShowCheckBox Example</h3>
<asp:TreeView id="BookTreeView"
DataSourceID="BookXmlDataSource"
OnTreeNodeDataBound="Data_Bound"
ShowCheckBoxes="None"
ExpandDepth="2"
runat="server">
<DataBindings>
<asp:TreeNodeBinding DataMember="Book" TextField="Title"/>
<asp:TreeNodeBinding DataMember="Chapter" TextField="Heading"/>
<asp:TreeNodeBinding DataMember="Section" TextField="Heading"/>
</DataBindings>
</asp:TreeView>
<asp:XmlDataSource id="BookXmlDataSource"
DataFile="Book.xml"
runat="server">
</asp:XmlDataSource>
</form>
</body>
</html>
<%@ Page Language="VB" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
Sub Data_Bound(ByVal sender As Object, ByVal e As TreeNodeEventArgs)
' Determine the depth of a node as it is bound to data.
' If the depth is 1, show a check box.
If e.Node.Depth = 1 Then
e.Node.ShowCheckBox = True
Else
e.Node.ShowCheckBox = False
End If
End Sub
</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>TreeNode ShowCheckBox Example</title>
</head>
<body>
<form id="form1" runat="server">
<h3>TreeNode ShowCheckBox Example</h3>
<asp:TreeView id="BookTreeView"
DataSourceID="BookXmlDataSource"
OnTreeNodeDataBound="Data_Bound"
ShowCheckBoxes="None"
ExpandDepth="2"
runat="server">
<DataBindings>
<asp:TreeNodeBinding DataMember="Book" TextField="Title"/>
<asp:TreeNodeBinding DataMember="Chapter" TextField="Heading"/>
<asp:TreeNodeBinding DataMember="Section" TextField="Heading"/>
</DataBindings>
</asp:TreeView>
<asp:XmlDataSource id="BookXmlDataSource"
DataFile="Book.xml"
runat="server">
</asp:XmlDataSource>
</form>
</body>
</html>
O código a seguir é um exemplo de dados XML para o exemplo anterior.
<Book Title="Book Title">
<Chapter Heading="Chapter 1">
<Section Heading="Section 1">
</Section>
<Section Heading="Section 2">
</Section>
</Chapter>
<Chapter Heading="Chapter 2">
<Section Heading="Section 1">
</Section>
</Chapter>
</Book>
Comentários
O TreeView controle permite exibir uma caixa de seleção ao lado da imagem de um nó. Use a ShowCheckBox propriedade para mostrar ou ocultar a caixa de seleção do nó atual.
Embora a ShowCheckBox propriedade possa ser usada para exibir caixas de seleção, é mais comum usar a TreeView.ShowCheckBoxes propriedade do TreeView controle. A TreeView.ShowCheckBoxes propriedade, no entanto, afeta todos os tipos de nó especificados pela propriedade; portanto, a TreeNode.ShowCheckBox propriedade geralmente é usada para substituir essa configuração para um nó individual.
Como a TreeView.ShowCheckBoxes propriedade é uma propriedade de três estados, o seguinte snippet de código C# causa um erro de compilação:
protected void TreeView1_SelectedNodeChanged(object sender, EventArgs e)
{
if (TreeView1.Nodes[0].Expanded)
{
// some work here
}
}
Enquanto VB.Net implicitamente converte o Boolean
valor em um NullableBoolean
, C# não. Portanto, é uma prática recomendada verificar explicitamente o estado da propriedade. Por exemplo, os exemplos de código a seguir em Visual Basic e C# testam explicitamente o valor da Expanded propriedade.
O exemplo de código Visual Basic a seguir testa explicitamente o valor da Expanded propriedade. Este exemplo testa se a Expanded propriedade está definida True
como ; portanto Nothing
, e False
se enquadra na instrução If
.
If TreeView1.Nodes(0).Expanded = True Then 'some work hereEnd IF
Este exemplo de código C# testa explicitamente o valor da Expanded propriedade. Este exemplo testa se a Expanded propriedade está definida True
como ; portanto Null
, e False
se enquadra na instrução If
.
if( TreeView1.Nodes[0].Expanded == true ) { //some work here}
O valor dessa propriedade é armazenado no estado de exibição.