自动回送与视图状态(AutoPostBack and ViewState)

本文探讨了ASP.NET中的自动回送机制及其实现原理,详细介绍了AutoPostBack属性的作用及其背后的JavaScript方法_doPostBack。同时,文章还深入解析了视图状态的功能和工作流程,解释了如何通过视图状态保持客户端更改。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

读asp.net 3.5高级程序设计的一些笔记。

    自动会送

    .net许多控件都有一个AutoPostBack的属性,这个属性就是用于自动回送的。如一个textbox控件,如果你需要通过改变textbox中的内容即向服务器回发一次请求,触发服务器端的事件响应,则可以将textbox的AutoPostBack的值设置为true,那么asp.net就会使用客户端的JavaScript来连接客户端和服务器的代码。

AutoPostBack的工作方式是,如果创建了一个包含一个或多个AutoPostBack属性设置为真的web控件,asp.net就会在呈现的html页面上添加一个名为——doPostBack()的JavaScript的方法,当该方法被调用时,它将触发一个回送,把窗体所有的信息回送到web服务器。asp.net还会添加两个隐藏的输入字段,_doPostBack()方法用他们把信息传回到服务器。这个信息包含引发该事件的控件的id以及其他任何相关的可能的附加信息如要处理的参数等等。这些字段初始化为空。

这是两个隐藏的输入字段:

<input type="hidden" name="__EVENTTARGET" id="__EVENTTARGET" value="" />
<input type="hidden" name="__EVENTARGUMENT" id="__EVENTARGUMENT" value="" />

这是_doPostBack()

<script type="text/javascript">
//<![CDATA[
var theForm = document.forms['form1'];
if (!theForm) {
    theForm = document.form1;
}
function __doPostBack(eventTarget, eventArgument) {
    if (!theForm.onsubmit || (theForm.onsubmit() != false)) {
        theForm.__EVENTTARGET.value = eventTarget;
        theForm.__EVENTARGUMENT.value = eventArgument;
        theForm.submit();
    }
}
//]]>
</script>

 

    视图状态

    一般情况下,每次页面被发送回服务器时,会收到有关用户进入<form>标签中的任意<input>控件的所有信息。asp.net将把网页载入它最初的状态(页面的默认设置)。但是如果在动态的网页结构下,如果客户端如果改变了网页的信息,然后回发到服务器端,当服务器端处理完请求之后,想要保持客户端上一次的改变(而不是又加载默认设置的页面)的时候,就要用到视图状态了。从本质上来说,网页代码运行完毕后(在最后的html被呈现给客户端之前),由asp.net检查你的网页上所有的控件的属性。如果任何一个属性从它最初状态开始发生了变化,asp.net在一个名称/值对的集合中会记录这一变化。最后asp.net把它收集到的全部信息序列化为一个Base64。最终的字符串作为一个新的隐藏字段插入到网页的<form>段中。

这是视图状态信息的隐藏输入框:

<input type="hidden" name="__VIEWSTATE" id="__VIEWSTATE" value="/wEPDwUJMzQzMDcwNzkyD2QWAgIDD2QWAgIDD2QWAmYPZBYCAgEPD2QWAh4Hb25jbGljawUoZ2V0RWxlbWVudEJ5SWQoJ01lc3NhZ2UnKS5pbm5lclRleHQgPSAnJ2RksG1aRzyBIi1QmAR77L5bywd47vc=" />

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值