zoukankan      html  css  js  c++  java
  • 控件的Visible设为false后,ViewState是否visible?

        在有很多地方为了方便需要在页面上放很多的控件,用panel来控制一组控件是否显示。这样做固然方便,但有没有考虑到对程序的影响呢?大家都知道ViewState的作用是保持控件乃致页面的状态。而把在页面上摆放很多控件会不会对程序产生影响呢?(前两天就被这个ViewState搞得很惨,回发事件执行很慢的问题.)这主要取决于一个控件(panel)的Visible属性设置为false时,控件是否还要保持状态。为此我做一个测试观察。我在一个页面中放两个panel,一个panel里面放DataGrid(DataGrid天生比较耗资源),另一个panel里面放普通的控件(这里面放两个ListBox)。

    //显示DataGrid
    private void ShowDataGrid(DataSet p_ds)
    {
    //放ListBox的panel设为不可见
       pnlListBox.Visible   = false
       dgrdData.DataSource  
    = p_ds;
       dgrdData.DataBind();   
    }

    //显示ListBox,不显示DataGrid
    private void ShowListBox()
    {
       pnlDataGrid.Visible  
    = false;
       pnlListBox.Visible   
    = true;
    }
    访问页面,查看源文件另存这个文件,大小如下:显示DataGird的时候文件的大小是100K(打开源文件都有点慢),而在显示Listbox的面板的时候文件大小是:42K,显然DataGrid的状态还是保持着的。虽然没有数据,这对页面还是有很大的影响的。对上面的代码进行修改如下:
    //显示DataGrid
    private void ShowDataGrid(DataSet p_ds)
    {
    //放ListBox的panel设为不可见
       pnlListBox.Visible   = false
    //DataGrid保持状态
       lbListBox1.EnableViewState  = true

       dgrdData.DataSource  
    = p_ds;
       dgrdData.DataBind();
    }

    //显示ListBox,不显示DataGrid
    private void ShowListBox()
    {
       pnlDataGrid.Visible  
    = false;
    //DataGrid不保持状态
       pnlDataGrid.EnabledViewState = false;

       pnlListBox.Visible   
    = true;
    }

    经过上面的修改,在显示ListBox面板的时候,页面文件的大小是:12K 显然瘦了不少啊!(要是减肥有这么明显就好了)。
        测试结果表明,在使用Visible动态设置一个控件是否显示的时候要关心一个ViewState的大小是否对程序有影响。在使用"胖"控件的时候要注意少使用Visible,如果非要使用尽量连同EnableViewState一起进行管理。顺便提一下,尽量少用ViewState存储对象,以减少序列反序列化带来的性能损耗,并且减轻服务器和客户端的压力,否则遇到跟我一样的问题可就麻烦了。(树控件的tag属性好像就是使用ViewState进行存储对象的)。

    注:上面的代码是为了说明问题的伪代码,另根据页面和数据的不同以上数值可能有不一样.
  • 相关阅读:
    Java关键字——instanceof
    C#基础知识整理 IList接口——非泛型
    .Net 中HashTable,HashMap 和 Dictionary<key,value> 和List<T>和DataTable的比较
    JS 判断是否为null
    java数组与字符串相互转换、整型与字符串相互转换
    数组元素的反转
    IOS系统中点击失效
    vue中计算属性和方法的区别,演示代码
    VUE中使用的插件有哪些?为什么,不能自动补全,script,methods和export default?
    【VueJS】实例中data属性的三种写法及区别
  • 原文地址:https://www.cnblogs.com/hjf1223/p/233335.html
Copyright © 2011-2022 走看看