用户控件-TreeView的用法

Treeview中 ontreenodepopulate是一个很好的事件,当你点击树的某个节点时调入数据库展现此节点下的数据,并且无刷新,当树展现的数据多的时候就可以用此方法如MSDN的树,但如果数据不多的时候没有必要用此方法,因为要频繁调数据库
好闲话少说
由于是用户控件所以把 treeview的部分属性和事件公共,方便用此控件的页面调用
页面 TreeDept.ascx
<%@ Control Language="C#" AutoEventWireup="true" CodeFile="TreeDept.ascx.cs" Inherits="UserControls_TreeDept" %>
<asp:TreeView ID="TreeView1" runat="server" ExpandDepth="1" ImageSet="Contacts"
    NodeIndent="10" onselectednodechanged="TreeView1_SelectedNodeChanged"
    ontreenodepopulate="TreeView1_TreeNodePopulate" Width="101px">
    <ParentNodeStyle Font-Bold="True" ForeColor="#5555DD" />
    <HoverNodeStyle Font-Underline="False" />
    <SelectedNodeStyle Font-Underline="True" HorizontalPadding="0px"
        VerticalPadding="0px" />
    <NodeStyle Font-Names="Verdana" Font-Size="8pt" ForeColor="Black"
        HorizontalPadding="5px" NodeSpacing="0px" VerticalPadding="0px" />
</asp:TreeView>

TreeDept.ascx.CS

public partial class UserControls_TreeDept : System.Web.UI.UserControl
{
  
    public event EventHandler DeptSel;
    public string DeptSelectNodeText
    {
        get { return TreeView1.SelectedNode.Text; }
    }
    SqlConnection con = new SqlConnection(@"server=LT-C9A4FDA64461;uid=sa;pwd=sa;database=ltweb");
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            BindTree();
        }
    }
    void BindTree()
    {
        TreeNode tn = new TreeNode();
        tn.Text = "软件";
        tn.Value = "1";
        tn.PopulateOnDemand = true;
        TreeView1.Nodes.Add(tn);

    }

    protected void TreeView1_TreeNodePopulate(object sender, TreeNodeEventArgs e)
    {
        SqlCommand cmd = new SqlCommand("select * from dept where parentID="+int.Parse(e.Node.Value),con);
        SqlDataAdapter sda = new SqlDataAdapter(cmd);
        DataTable dt = new DataTable();
        sda.Fill(dt);
        foreach (DataRow dr in dt.Rows)
        {
            TreeNode tn = new TreeNode(dr["Dept_Name"].ToString(), dr["Dept_ID"].ToString());
            tn.PopulateOnDemand = true;
            e.Node.ChildNodes.Add(tn);

        }
    }
    protected void TreeView1_SelectedNodeChanged(object sender, EventArgs e)
    {
        if(DeptSel!=null)
        DeptSel(this,EventArgs.Empty);
    }
}

调用页面
 <form id="form1" runat="server">
    <div>
   
        <uc1:TreeDept ID="TreeDept1" runat="server" OnDeptSel="DeptSel_Change"/>
   
    </div>
    </form>

后台

public partial class Dept : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {

    }
    protected void DeptSel_Change(object sender, EventArgs e)
    {
        Response.Write(TreeDept1.DeptSelectNodeText);
    }
}



转载于:https://www.cnblogs.com/luca623/archive/2008/01/04/1025905.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值