在页面的HTML代码上设置一个asp:PlaceHolder 站位控件,当页面被加载的时候,在这个PlaceHolder控件上添加所需要的其他控件。











2、遍历控件的方法。
页面可以被看成各种控件组成的一个集合。在页面被初始化和加载过程中,可以遍历这些控件,找到特定的控件,或者改变某些控件的属性。
先看下面的一个例子:























这个例子列出页面上所有的控件,结果如下:
A List of the Controls in the Controls
Collection
System.Web.UI.LiteralControl -
System.Web.UI.WebControls.Label - lblControlList
System.Web.UI.LiteralControl -
System.Web.UI.HtmlControls.HtmlForm -
System.Web.UI.ResourceBasedLiteralControl -
特别要注意的一点:以上代码没有列出ID=“txtName”的TextBox控件!因为这个TextBox控件包含在Form里面,是Form的一个子控件。而我们的代码 foreach(Control c in Controls) 只关心当前页面Controls的控件,至于子控件却未能涉及。(可以把这些控件理解成一个树状的层次关系)
页面Controls
/ | \ //foreach(Control c in Controls)
控件1 控件2 控件3 // 只判断控件1、2、3属于页面Controls
/ \ //而未涉及到下属子控件
子控件1 子控件2
为了真正做到遍历所有控件集,可以用递归的方法来实现:






































以上代码运行结果如下:
A List of the Controls in the Controls
Collection
- System.Web.UI.LiteralControl
- System.Web.UI.WebControls.Label
- System.Web.UI.LiteralControl
- System.Web.UI.HtmlControls.HtmlForm
- System.Web.UI.LiteralControl
- System.Web.UI.WebControls.TextBox
- System.Web.UI.LiteralControl
- System.Web.UI.ResourceBasedLiteralControl
这下TextBox控件真的露出了庐山真面目。
3、动态地创建控件、遍历创建的控件以及改变控件属性的一个应用。
用户输入一个1-10的整数,按按钮后动态创建相应数字的TextBox。代码如下:




















































总结: 理解asp.net页面的组成及控件的层次结构,通过递归实现控件遍历。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述