asp.net原理笔记----页面控件类型,页面状况和asp.net编译过程
2014-07-07 23:19
281 查看
通过查看asp.net的整个生命周期之后
了解到在aspx的页面生命周期中
调用了BuildControlTree()方法生成页面控件树
之后再调用Rend()方法根据控件树生成html返回
aspx页面上有3种控件类型
1.html标签,在服务器端被当作字符串,不做特殊处理
2.runat="server"标签,那么在网站编译程序集的时候,该页面的后台类会自动创建一个Protect
修饰的服务器控件类对象(如:protected HtmlGenericControl divMsg;)
正是因为protect,在后台类中可以访问,在其子类前台类中也可以访问(注意:这个控件变量中有一
个Render方法专门根据该控件的属性来生成对应的html字符串)
例子:
protected HtmlGenericControl divMsg;
protected HtmlForm form1;
protected HtmlImage imgs;
protected HtmlGenericControl spanMsg;
protected string strName;
protected HtmlInputText txtName;
HtmlGenericControl主要对应非表单控件的标签
3.ASP服务器控件<ASP:Button>,此种控件必须放在runat=server的form中。服务器专属控件
与第二种控件的区别:runat="server"控件在后台访问时,其属性等都和html标签一样访问,
而ASP服务器控件在后天访问属性时像winform的控件一样访问,如:
1.后台是string(添加到控件树时时LiteralControl)类
2.runat="server"控件在后台生成的变量是HtmlForm等这些类
3.ASP服务器控件后台生成的是Button等这些类
根据不同的控件类型
将在生命周期中对应着不同的处理方式
这就是为什么服务器端的控件响应速度慢,html代码被当做字符串不做特殊处理原样返回当然比要经过一系列转换和生成的服务器控件响应速度快呀~
aspx的页面状况:
1.当页面上没有包含任何服务器端语言的时候(<%%>、 runat="server"),整个页面作为 文本
资源供程序集使用。
2.当页面中包含 <%%>和html代码字符串时,当前前台页面类里会自动生成一个 方法,这个方法
中 向一个写出器对象里 吸入页面的html代码,和执行 <%%>内的内容。
3.当页面中既包含<%%>、html代码字符、runat=server的html、服务器控件标签时,那么前台页
面类会为每个runatserver的控件都创建一个方法,并通过 buildControlTree方法来组织各个控
件的依赖(包含)关系
Asp编译过程:
Client->Server->.Net Framework->判断内存中是否有相应的机器码->有,则交给cup执行返回给上一层,没有,则判断c盘中是否有相应的中间代码文件->有,则交给jit编译生成机器码返回给上一层并存在内存中,没有则将对应的aspx文件和aspx.cs合并用中间语言编译成一个类返回给上一层并存在C盘中
如下图所示:
了解到在aspx的页面生命周期中
调用了BuildControlTree()方法生成页面控件树
之后再调用Rend()方法根据控件树生成html返回
aspx页面上有3种控件类型
1.html标签,在服务器端被当作字符串,不做特殊处理
2.runat="server"标签,那么在网站编译程序集的时候,该页面的后台类会自动创建一个Protect
修饰的服务器控件类对象(如:protected HtmlGenericControl divMsg;)
正是因为protect,在后台类中可以访问,在其子类前台类中也可以访问(注意:这个控件变量中有一
个Render方法专门根据该控件的属性来生成对应的html字符串)
例子:
protected HtmlGenericControl divMsg;
protected HtmlForm form1;
protected HtmlImage imgs;
protected HtmlGenericControl spanMsg;
protected string strName;
protected HtmlInputText txtName;
HtmlGenericControl主要对应非表单控件的标签
3.ASP服务器控件<ASP:Button>,此种控件必须放在runat=server的form中。服务器专属控件
与第二种控件的区别:runat="server"控件在后台访问时,其属性等都和html标签一样访问,
而ASP服务器控件在后天访问属性时像winform的控件一样访问,如:
1.后台是string(添加到控件树时时LiteralControl)类
2.runat="server"控件在后台生成的变量是HtmlForm等这些类
3.ASP服务器控件后台生成的是Button等这些类
根据不同的控件类型
将在生命周期中对应着不同的处理方式
这就是为什么服务器端的控件响应速度慢,html代码被当做字符串不做特殊处理原样返回当然比要经过一系列转换和生成的服务器控件响应速度快呀~
aspx的页面状况:
1.当页面上没有包含任何服务器端语言的时候(<%%>、 runat="server"),整个页面作为 文本
资源供程序集使用。
2.当页面中包含 <%%>和html代码字符串时,当前前台页面类里会自动生成一个 方法,这个方法
中 向一个写出器对象里 吸入页面的html代码,和执行 <%%>内的内容。
3.当页面中既包含<%%>、html代码字符、runat=server的html、服务器控件标签时,那么前台页
面类会为每个runatserver的控件都创建一个方法,并通过 buildControlTree方法来组织各个控
件的依赖(包含)关系
Asp编译过程:
Client->Server->.Net Framework->判断内存中是否有相应的机器码->有,则交给cup执行返回给上一层,没有,则判断c盘中是否有相应的中间代码文件->有,则交给jit编译生成机器码返回给上一层并存在内存中,没有则将对应的aspx文件和aspx.cs合并用中间语言编译成一个类返回给上一层并存在C盘中
如下图所示:
相关文章推荐
- asp.net原理笔记----页面控件类型,页面状况和asp.net编译过程
- C#向用户控件中传递参数(涉及Asp.net页面的执行过程)
- .NET 1.1中预编译ASP.NET页面实现原理浅析 [1] 自动预编译机制浅析
- 递归输出ASP.NET页面所有控件的类型和ID的代码
- .NET 1.1中预编译ASP.NET页面实现原理浅析 [1] 自动预编译机制浅析
- ASP.NET动态加载用户控件的页面生成过程
- .NET 1.1中预编译ASP.NET页面实现原理浅析 [1] 自动预编译机制浅析(转贴)
- 深入理解 ASP.NET 动态控件 (Part 2 - 编译过程)
- .NET 1.1中预编译ASP.NET页面实现原理浅析
- ASP.NET动态加载用户控件的页面生成过程
- 递归输出ASP.NET页面所有控件的类型和ID
- ASP.NET 3.5核心编程学习笔记(36):页面的视图状态和控件状态
- 深入理解 ASP.NET 动态控件 (Part 2 - 编译过程)
- 深入理解 ASP.NET 动态控件 (Part 2 - 编译过程)
- net控件中数据导到Excel的格式 首先,我们了解一下excel从web页面上导出的原理。当我们把这些数据发送到客户端时,我们想让客户端程序(浏览器)以excel的格式读取它,所以把mime类型设为:application/vnd.ms-excel,当excel读取文件时会以每个cell的格式呈现数据,如果cell没有规定的格式,则excel会以默认的格式去呈现该cell的数据。这样就给我们提供了自定义数据格式的空间,当然我们必须使用excel支持的格式。下面就列出常用的一些格式: 1) 文本
- ASP.NET动态加载用户控件的页面生成过程
- ASP.NET动态加载用户控件的页面生成过程
- .NET1.1中预编译ASP.NET页面实现原理浅析[1]自动预编译机制浅析
- asp.net简单实现禁用或启用页面中的某一类型的控件
- ASP.NET页面事件过程-多个用户控件时的执行过程