asp.net – 为什么DropDownList.SelectedValue依赖于viewstate?

前端之家收集整理的这篇文章主要介绍了asp.net – 为什么DropDownList.SelectedValue依赖于viewstate?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如果我设置在我的页面上:EnableViewState =“true”ViewStateMode =“Disabled” – 然后 – Viewstate被禁用该页面(除非覆盖…)

然后,尝试读取(假设控件已经在最后一个转储中填充到屏幕,并且选择了一个值):

MyDDL.SelectedValue将产生“”

这是因为禁用的viewstate:

但我的问题是在更高的层次上:

>如果这一切都是关于一个表单值(我仍然可以从Request.Form [MyDDL.UniqueID]获得)) – 我们在谈论一个不需要任何东西来保存它的值的输入.
>为什么名为(SelectedValue)的DropDownList属性依赖于ViewState?

附: TextBox onchangeevent确实依赖于viewstate,虽然控件是一个输入(不需要viewstate) – 它保存文本的值,然后在postback时比较它.但是当您设置onchange事件(和autopostback)时,它只依赖于viewstate,

解决方法

摘要:如果希望控件在没有ViewState的情况下运行,则需要在每个回发上填充/绑定Items集合.我建议在Page_Init事件(即OnInit方法)中进行.

首先,我总是推荐这个这个真棒的文章TRULY Understanding ViewState.

SelectedValue不需要ViewState.看看DropDownList继承的ListControl的代码,我们看到代码

public virtual string SelectedValue
{
  get
  {
    int selectedIndex = this.SelectedIndex;
    if (selectedIndex >= 0)
      return this.Items[selectedIndex].Value;
    else
      return string.Empty;
  }

从此代码删除的重要事项是必须填充Items列表以获取SelectedValue.

如果您使用ViewState,则Items集合将从ViewState中持久化到/加载,这允许SelectedValue属性在不重新绑定控件的情况下工作.

猜你在找的asp.Net相关文章