浅谈ViewState

一、ViewState概述

ViewState是基于webform的


② 在web窗体控件属性处设置runat = "server",这个控件会被附加一个隐藏的属性_ViewState,_ViewState存放了所有控件在ViewState中的状态值。


③ 页面会在输出时,自动添加下面的隐藏域:


value处的值只是base64编码并不是加密。

④ ViewState是一个名称/值的对象集合。


⑤ 当请求某个页面时,ASP.NET会把所有控件的状态序列化成一个字符串,然后作为窗体的隐藏属性送到客户端,当客户端将页面回传时,ASP.NET分析回传的窗体属性,并赋给控件对应的值。(恢复现场)


⑥ ViewState不能存储所有的数据类型,仅支持:String、Integer、Boolean、Array、ArrayList、Hashtable

二、ViewState原理


① 浏览器请求Default.aspx页面。

② 在服务器端 发现创建的ViewState 这个时候 会自动创建一个名字叫做__VIEWSTATE(双下滑线 全部是大写)的隐藏域 其隐藏域的值经过base64加密以后返回到浏览器端这一加密过程在页面生命周期的SaveState事件中的SaveAllState方法中完成。

③ 当浏览器提交表单的时候 将__VIEWSTATE的隐藏域也一起提交到服务端 这个时候 页面生命周期的ReadState事件的ReadAllState方法会将加密后的值反base64解密 最后将值赋值给名字叫做xx的ViewState。

④ 最后来操作ViewState中的值。


三、使用

1.使用原因

由于http是无记忆无状态的协议。页面传值给服务器,都是通过form表单,且控件自己必须有name属性与value才可以得到值。但是像显示动态信息很多情况下并不都是使用满足上述条件的控件,所以需要将http伪装为有记忆的。而viewstate就是可以事先这个伪装术的策略。

2.使用方法

① 条件与设置


② 实例
aspx.cs文件:




aspx界面(就一个自增按钮):




运行效果:


③ 禁用方法

在默认情况下,所有服务器控件的viewstate开启状态,通过以及几种途径来禁止。
1.页面级别
2.控件级别
3.应用程序级别
4.机器级别


页面级别禁止的方法是在页面的开始写入
<span style="font-family:Microsoft YaHei;"> <% @ Page EnableViewState  = " False "   %>  
or 
 <% @ Page EnableViewState  = " True "   %></span>




控件级别是
<span style="font-family:Microsoft YaHei;"> < asp:TextBox id = " txtCode "  runat = " server” EnableViewState= " false "  /> 
 or
 < asp:TextBox id = " txtCode "  runat = " server "  EnableViewState = " true "   /></span>

也可以直接在控件处修改



程序级别是在web.config中
<span style="font-family:Microsoft YaHei;">< pages enableViewState = " false "   /> 
or
 < pages enableViewState = " true "   />
</span>

机器级别是在machine.config中
<span style="font-family:Microsoft YaHei;"> < pages enableViewState = " true "  enableViewStateMac = " true "  ...  /> 
or
 < pages enableViewState = " false "  ...  /> </span>


四、补充

1.回忆与直接写值不同

如果将ViewState禁用后,还是可以在服务器端给控件text赋值的。但是不可回忆(不可还原现场)。通过下面这个实例来感受下。

aspx.cs文件:



界面:

一个label和一个按钮


运行效果:



2.读取viewstate中的值都是开始键值对捆绑设定好的。如果改键未设定值时,读出来的是空。

对上面使用中介绍的ViewState进行一点改进。

aspx.cs文件:


界面:

同上

运行效果:




  • 11
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
ASP.NET ViewState 是一种用于在 Web 应用程序中跨请求存储数据的机制。以下是一个使用 ViewState 的示例: 假设您有一个页面,其中包含一个文本框和一个按钮。用户在文本框中输入一些文本,然后单击按钮。在单击按钮时,将在服务器端处理程序中使用 ViewState 存储文本框中的值,并在页面上显示它。 以下是一个简单的 ASP.NET 页面代码示例,它演示了如何使用 ViewState 存储和检索文本框中的值: ```html <%@ Page Language="C#" %> <!DOCTYPE html> <html> <head runat="server"> <title>ViewState Example</title> </head> <body> <form id="form1" runat="server"> <div> <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox> <br /> <asp:Button ID="Button1" runat="server" Text="Save" OnClick="Button1_Click" /> <br /> <asp:Label ID="Label1" runat="server"></asp:Label> </div> </form> </body> </html> ``` 在按钮单击事件处理程序中,我们将文本框中的值存储在 ViewState 中,并将其显示在页面上: ```csharp protected void Button1_Click(object sender, EventArgs e) { string text = TextBox1.Text; ViewState["myText"] = text; Label1.Text = "Text saved: " + text; } ``` 在页面加载事件处理程序中,我们检索存储在 ViewState 中的值,并将其显示在页面上: ```csharp protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { if (ViewState["myText"] != null) { string text = (string)ViewState["myText"]; Label1.Text = "Text retrieved: " + text; } } } ``` 通过这种方式,我们可以在页面上保留用户在文本框中输入的值,即使用户单击其他按钮或导航到其他页面。请注意,ViewState 可能会增加页面大小,并增加网络传输时间。因此,我们应该谨慎使用 ViewState,并仅在必要时使用它。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值