可编辑的DropDownList-vs2005(c#)

找了很多文章,发觉网上有两种设计方案,一种是ASP的 一种是基于VS2003的,但其中都有共同的地方.这里谈谈第一种方案在VS2005的运用

首先创建一个页面ascx 代码入图

 

 

ContractedBlock.gif ExpandedBlockStart.gif Code
 1<%@ Control Language="C#" AutoEventWireup="true" CodeFile="DropDownListExtend.ascx.cs" Inherits="WebUserControl" %>
 2
 3<style>
 4ExpandedBlockStart.gifContractedBlock.gif.cls1 {
 5  WIDTH: 15%;  POSITION:absolute; 
 6}

 7ExpandedBlockStart.gifContractedBlock.gif.cls2 {
 8 WIDTH: 15%; POSITION: absolute ; 
 9}

10</style> 
11<div class="cls1" style="WIDTH: 175px;  CLIP: rect(2px 280px 21px 155px); " align="center"></div>
12<div class="cls2" style="WIDTH: 175px ;"align="center" >
13   <asp:TextBox ID="TextBox1" runat="server" Width="164px" Height="15px" OnTextChanged="TextBox1_TextChanged"></asp:TextBox></div>
14   <asp:DropDownList ID="DropDownList1"  runat ="server"  Width="172px" Height="25px" OnSelectedIndexChanged="DropDownList1_SelectedIndexChanged" AutoPostBack="True"      ></asp:DropDownList>
15

然后编写后台C#代码

 

 

ContractedBlock.gif ExpandedBlockStart.gif Code
 1
 2
 3//自定义控件 扩展了DropDownList控件的功能 增加了可输入数据的功能
 4//2006-07-01 Mode by horse
 5//这里只编写了一些常用的属性和方法 特殊的属性和方法可自由扩展
 6//使用方法 
 7//控件声明
 8//     <%@ Register src="/blog/DropDownListExtend.ascx" TagName="WebControl" TagPrefix="uc" %>
 9//装入控件 <uc:WebControl ID="MyDropDownList" runat ="Server" />
10using System;
11using System.Data;
12using System.Configuration;
13using System.Collections;
14using System.Web;
15using System.Web.Security;
16using System.Web.UI;
17using System.Web.UI.WebControls;
18using System.Web.UI.WebControls.WebParts;
19using System.Web.UI.HtmlControls;
20
21public partial class WebUserControl : System.Web.UI.UserControl
22ExpandedBlockStart.gifContractedBlock.gif{
23    protected void Page_Load(object sender, EventArgs e)
24ExpandedSubBlockStart.gifContractedSubBlock.gif    {
25
26    }

27// Text 重写了TextBox的Text属性 
28    public String Text
29ExpandedSubBlockStart.gifContractedSubBlock.gif    {
30        get
31ExpandedSubBlockStart.gifContractedSubBlock.gif        {
32            return Text;
33        }

34        set
35ExpandedSubBlockStart.gifContractedSubBlock.gif        {
36            this.TextBox1.Text = Text;
37        }

38    }

39
40    //为控件增加一个可选择的项
41    public  void AddItem(String item)
42ExpandedSubBlockStart.gifContractedSubBlock.gif    {
43        this.DropDownList1.Items.Add(item);
44    }

45
46    //为控件增加一个可选择的项
47    public   void AddItem(ListItem  item)
48ExpandedSubBlockStart.gifContractedSubBlock.gif    {
49        this.DropDownList1.Items.Add(item);
50    }

51
52    //为控件增删除一个可选择的项
53    public  void RemoveItem(ListItem item)
54ExpandedSubBlockStart.gifContractedSubBlock.gif    {
55        this.DropDownList1.Items.Remove(item);
56    }

57    //为控件增删除一个可选择的项
58    public  void RemoveItem(String item)
59ExpandedSubBlockStart.gifContractedSubBlock.gif    {
60        this.DropDownList1.Items.Remove(item);
61    }

62
63    //清除控件数据
64    public  void Clear()
65ExpandedSubBlockStart.gifContractedSubBlock.gif    {
66        this.DropDownList1.Items.Clear();
67        this.TextBox1.Text = "";
68    }

69    //返回选项数量
70    public  int Count
71ExpandedSubBlockStart.gifContractedSubBlock.gif    {
72
73        get
74ExpandedSubBlockStart.gifContractedSubBlock.gif        {
75          return   this.DropDownList1.Items.Count;
76        }

77
78
79    }

80
81    protected void TextBox1_TextChanged(object sender, EventArgs e)
82ExpandedSubBlockStart.gifContractedSubBlock.gif    {
83
84    }

85
86
87   //选择某项
88    protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
89ExpandedSubBlockStart.gifContractedSubBlock.gif    {
90        this.TextBox1.Text = this.DropDownList1.Text;
91    }

92}

93
94

这样一来 你就可以使用该控件了

 

转载于:https://www.cnblogs.com/jdmei520/archive/2009/06/06/1497733.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值