面试遇到过,但是一直没怎么在意,今天感觉这个问题还是比较重要的,所以翻出来问问?其实主要是问问GridView这样的ViewState超级生产户在禁用了ViewState时该如何“生存”?能给个例子最好了。
以前试着写了一个绑定DropDownLIst的demo,在没有禁掉viewstate时,只需要在Page_Load()事件里面写if(!IsPostback)
{
    Bind();//绑定ddl控件
}那么这样再在页面回发时不用执行Bind()函数,ddl控件里面的值还是存在的——个人感性的认为,少执行一遍Bind()代码,相对维护viewstate影响的性能差不多。:-D当我禁掉viewstate时,在页面会发时,ddl控件里面的值就没有了(我的解决方法是去掉if(!IsPostback){}这个判断,等于每次加载页面的时候都执行一次,感觉性能肯定有点影响,所以还不如保持viewstate得了。)请问这两种方法那种好呢?又或者都是比较菜的???大牛们都出来!
谢谢!

解决方案 »

  1.   

    禁用ViewState 后你看ItemCommand还能使不。
      

  2.   

    1.不想要viewstate就不要用asp.net了,以现在的技术手段,html+js+WCF不比asp.net逊色
      你可以自己从头写js库,也可以结合JQ,MsAjax.js等开源库
    2.即使使用html+js,往返的数据交易量也不见得比asp.net少
      很多人仅仅是看到页面上没有hidden,心里面就舒坦了
      

  3.   


    不懂wcf,也是做web方面的吗???不管别人怎么样,我需要了解了解,明白了才能有自己的理解、自己的方法嘛。。
      

  4.   


    即使不能得到满意的答案、理想的结果也可以当做一个了解.net的“切入点”嘛!!!用很多个“不理解”去“围剿”.net !!!
      

  5.   

    既想依托ASP.NET强大与便利,又不想看到ViewState,可以使用ASP.NET MVC替换ASP.NET WebForm
    MVC可自由控制HTML的输出
    此观点纯属个人愚见
      

  6.   

    viewstate 是服务器控件的专属,用来页面回发时保存服务器控件的value;
    会产生额外的hidden在里面; 那么如果像服务器控件比如绑定控件,少了viewstate很多高级功能就无法使用;
    所以,如果你是前台 建议少用服务器控件,禁用viewstate,改用js+div+css+轻量级的ashx或者wcf,来做你的webform;或者干脆用asp.net mvc好了,这个更直接!
     后台的话,用服务器控件可以提高生产率,还是建议使用,毕竟后台是几个人用罢了,性能无所谓功能实现就ok!!
    欢迎.net家族的斗士们,踊跃加入,共同探讨微软.net的奥秘,共同维护和推广.net的应用!69594961
      

  7.   

    比如说你随便放一个Label控件,假设操作中你把它的ForeColor修改了,假设禁用ViewState,那么任何回发都会让你丢失这个状态。而假设你自己维护它......一个复杂的交互页面上你需要维护的这类状态何止成千上万?!对于只是想做网页的,可以考虑禁用ViewState。对于想做交互应用程序的,首要地是先想好应该如何测试交互操作过程,然后才编码,而不能为了编码而编码。
      

  8.   


    使用“js+div+css+轻量级的ashx或者wcf”跟asp.net.mvc有什么关系?都避免回发了,那么后台使用任何跟控件没有关系的东西比如ashx、asmx都是与控件无关的处理请求的直接方法,不是说只有asp.net mvc才可以处理请求。
      

  9.   

    我有时做网站时也会试着禁用ViewState但做交互型的应用程序时就不大敢去禁用,因为对它的了解的不够深!
    不过我个人也很爱好html+js+wcf|webService这种方式的开发,ASP.NET MVC也很有意思,但了解的不够深,感觉太依赖于微软了,引用了好多东西。我还是偏喜欢开源的。
      

  10.   

    http://msdn.microsoft.com/zh-cn/library/y5y3c2c5(v=vs.80).aspxhttp://msdn.microsoft.com/zh-cn/library/75x4ha6s(v=VS.90).aspxhttp://msdn.microsoft.com/zh-cn/library/system.web.ui.control.viewstate(v=VS.90).aspx
      

  11.   


    和我感觉差不多。。不过我不喜欢“太过分”使用js,举一个例子,“全选”操作,不管js是否发挥作用(是否被警用掉),都不会影响你的程序,如果用户禁掉了js,那么他就只能一个一个的单选了我觉得比较重要的功能、禁用掉js就应影响程序运行的……都不应该使用js实现!客户怎么操作是他的权利,就连腾讯都要变相的说将选择权交给用户。
      

  12.   

    大部份情况完全可以禁用ViewState,对你的应用程序毫无影响。至于在GridView中,我记得是禁用ViewState后,分页数字点了将会没有反应。也就是不能分页了。
      

  13.   

    ViewState并完全是一个坏东西,甚至你可以自己往里面存信息。
      

  14.   

    从缓存的角度看,ViewState很有用,因为他可以作为页面的一部分,缓存仅仅与某个特定页面相关的信息。
      

  15.   

    简单的说,就是无法通过<form>进行会发的HTML元素的值,比如Span,必须通过隐藏字段回发,所以就有了ViewSatate,不知道你是否明白?
      

  16.   

    就lz举的这个例子
    当我禁掉viewstate时,在页面会发时,ddl控件里面的值就没有了(我的解决方法是去掉if(!IsPostback){}这个判断,等于每次加载页面的时候都执行一次,感觉性能肯定有点影响,所以还不如保持viewstate得了。)去掉if(!ispostback)每次都会在执行一遍绑定,这样你选的值无论什么都是第一项。你可以在oninit事件中给dropdownlist绑定,不要在load事件中。
      

  17.   

    即使去掉viewstate在oninit事件中也可以获取到值。
      

  18.   

    即使去掉viewstate在oninit事件中绑定回发后也可以获取到值。
      

  19.   

    ViewState 是干嘛的? 用它有什么意义么?  不用行不行?
      

  20.   

    现在普遍的用户是不会去禁用JS的。现在禁用了JS程序运行不起来,我觉得不过分!比如说“没事你去禁用它做什么?”
      

  21.   


    电脑是我的,想怎么玩就怎么玩,呵呵!!如果是这样的话那我们也不必写哪么麻烦但是兼容性强的css代码了。。
      

  22.   


    主要是用来维持控件状态的。。用的意义是方便开发。。不用也可以,不过比较麻烦。。现在我就想试试这种比较麻烦的做法。。其实viewstate不仅仅是生成隐藏字段带来负面影响。其实维持这个viewstate也是消耗性能的一方面我不想纠结这两种的方法(是否禁用viewstate)那种更好、更合理我只想知道在禁掉viewstate后达到未禁用之前的效果
      

  23.   

    其实viewstate不仅仅是生成隐藏字段带来负面影响。其实维持这个viewstate也是消耗性能的一方面
    -----------------------------------------------------------------
    何讲?
    我只想知道在禁掉viewstate后达到未禁用之前的效果
    --------------------------------------------
    如果你想用自己的方式去实现viewstate的效果,全面衡量后你会发现 viewstate 的做法确实在 webform 中已经是最简形式了。
      

  24.   


    何讲?
    这个问题我是在msdn上看到的。其中有好几个生命周几的事件里面都用到了,viewstate,所以在创建viewstate、还原viewstate的时候至少会有点消影响吧。。另外我说的生成隐藏字段带来的负面影响指的是,当页面生成的viewstate过大时,会有宽带传输的压力
      

  25.   


    我不是说一定要以自己的方法实现viewstate我只是想找一种“更有效率”的开发方式
      

  26.   

    基于你的提问:
    在ASP.NET框架下,你想要完全禁用ViewState,那你就要完全手动去做到ViewState要做的.所以在ASP.NET下完全禁用ViewState对于业务交互频繁,回发频繁的业务系统,是相当划不来,会更加没有效率.因此你想要完全禁用ViewState,就要跳出ASP.NET框架.
      

  27.   

    楼上很多牛人都已经说清楚了,个人比较赞同sp1234的说法,个人愚见,ViewState主要是用来维持服务器的回发事件时,保持服务器控件的状态,当然也包括一些服务器的属性和值等,象gridview\repeater这类控件都是用来显示和交互数据库数据用的,所以如果只是用来显示的话,我认为完全可以禁掉ViewState,不过这样也还是会有一小部分的ViewState,因为你的gridview\repeater是要放在form的runat="server"里的.但如果gridview\repeater里有服务器事件的回发,就不要禁掉ViewState了.
     
      

  28.   


    嗯,这个理由是比较充分,和sp1234说的差不多看来没有更好的办法了如果要禁掉viewstate的话,那就换一种方法实现了。。例如:用js方面的表格插件来代替GridView这样的数据控件了
      

  29.   

    不管怎么说在asp.net中,或多或少肯定会产生viewstate
    如果viewstate太大的话你可以在保存视图状态时对viewstate进行压缩
    在加载到页面时对viewstate进行解压
      

  30.   

    要完全去掉。请去掉form runat=server 中的 runat=server
    然后代码中加
     public override void VerifyRenderingInServerForm(Control control)
      { }
      

  31.   

    asp.net下完全消除ViewState,是在替微软想一个代替ViewState的解决方案吗。
      

  32.   

    可以将ViewState保存在服务器,重写Page类的LoadPageStateFromPersistenceMedium和SavePageStateToPersistenceMedium方法。    public const string ViewKeyName = "__viewkey";    protected void Page_Load(object sender, EventArgs e)
        {
            if (!this.IsPostBack)
            {
                this.viewlabel.Text = "not postback";
                this.ViewState["ok"] = "this is the ViewState text";
            }
            else
            {
                this.viewlabel.Text = (string)this.ViewState["ok"];
            }
        }    protected override void SavePageStateToPersistenceMedium(object state)
        {
            string key = Guid.NewGuid().ToString();
            this.ClientScript.RegisterHiddenField(ViewKeyName, key);
            this.Cache[key] = state;
        }    protected override object LoadPageStateFromPersistenceMedium()
        {
            string key = this.Request[ViewKeyName];
            if (key == null)
                throw new InvalidOperationException("Invalid ViewState Key");
            object state = this.Cache[key];
            if (state == null)
                throw new InvalidOperationException("ViewState too old");
            return state;
        }
      

  33.   

    这个问题我是在msdn上看到的。其中有好几个生命周期的事件里面都用到了,viewstate,所以在创建viewstate、还原viewstate的时候至少会有点消影响吧。。另外我说的生成隐藏字段带来的负面影响指的是,当页面生成的viewstate过大时,会有宽带传输的压力
    -------------------------------------------------------
    没错,会有 SaveViewState 和 LoadViewState。生成viewstate过大 传输也会会受影响。但这并不是放弃viewstate的原因,如果你要放弃它,那么唯一的原因应该是你的应用不需要它。选择某个事物的时候,应该考虑它的利和弊。 对于viewstate来说利就是字面所呈现的“视图状态保持”的简单适用的场景是 页面回发(非异步)后的视图状态保持,因为异步的情况状态都在不存在需要保持这一说。基于这个前提去找相关的解决方案,会发现做法很类似付出的成本也一样,但 viewstate 从效率,融合度,易用性上都是最优的。
      

  34.   

    建议内部应用系统还是要用ViewState比较好,否则可以使用ASP.NET MVC
      

  35.   

    同意,不过有的人禁止viewstate为了搜索引擎更好的抓取.
      

  36.   


    asp.net MVC也属于asp.net 你找下ViewState
      

  37.   

    看你怎么使用,可以禁用。。翻页可以用aspnetpager那个控件。。完全可以达到你想要的效果。
      

  38.   

    看你怎么使用,可以禁用。。翻页可以用aspnetpager那个控件。。完全可以达到你想要的效果。回发事件就得好好控制..处理 .
      

  39.   

    记忆中,禁用后,下一次刷新数据就没了。。要重新获取,datalist不能联动
      

  40.   

    EnableViewState="false" 不能使用 foreach (Control c in this.Repeater1.Controls) 遍历控件
      

  41.   


    禁用掉viewstate很定有很多麻烦的。。这个需要研究一下再禁用,不然是自找麻烦。。其实上面说得很明白了。。一般的主要用来浏览性质的网站,禁掉viewstate没啥影响。。至于后台嘛,用的人很定要少一点,禁不禁用也没什么大不了的。。
      

  42.   

    禁用掉了,要自己来回传递控件的状态,framework不会帮你做这种事情了,如果禁用viewstate,那还不如去写asp.net mvc代码。
      

  43.   

    重事件不能用了,比如row_Commond,listGameView_SelectedIndexChanged 等。
    一些button的事件是不需要的