顺序
1控件初始化,控件没有任何属性。
2viewstate加载,将从页面post来的隐藏的viewstate重新解码回来。加载到控件上。如果是后台手动生成的viewstate也是同过程,存储的位置也是页面。
3载入input回来的值,以调用。
4加载控件(onload)
5控件事件
7把viewstate用base64再编码,保存,写入到页面。
8页面Render
9发送到客户
10将所有的对象dispose();
用户能看到回发后的状态就是靠ViewState功能,类似于InputHidden。
(个人理解,可能不对)每次将页面post前都将页面里变的Viewstate通过js重新写入,从而达到保存提交前的目的,再能过解码的方式实现。
当设置了AutoPostBack属性后,控件会在页面里自动生成一段与服务器事件相对应的隐藏js脚本,用这种方式达到与服务器端事件同步的目的。
如何保存js生成的html,可以能过一个runat="server"的inputHidden实现。用其它任何服务器端控件作为媒介都行,runat="server"后系统系统通过视力状态保存。
1控件初始化,控件没有任何属性。
2viewstate加载,将从页面post来的隐藏的viewstate重新解码回来。加载到控件上。如果是后台手动生成的viewstate也是同过程,存储的位置也是页面。
3载入input回来的值,以调用。
4加载控件(onload)
5控件事件
7把viewstate用base64再编码,保存,写入到页面。
8页面Render
9发送到客户
10将所有的对象dispose();
用户能看到回发后的状态就是靠ViewState功能,类似于InputHidden。
(个人理解,可能不对)每次将页面post前都将页面里变的Viewstate通过js重新写入,从而达到保存提交前的目的,再能过解码的方式实现。
当设置了AutoPostBack属性后,控件会在页面里自动生成一段与服务器事件相对应的隐藏js脚本,用这种方式达到与服务器端事件同步的目的。
如何保存js生成的html,可以能过一个runat="server"的inputHidden实现。用其它任何服务器端控件作为媒介都行,runat="server"后系统系统通过视力状态保存。