日期:2008-02-29  浏览次数:20650 次

Aiyiweb.Com提示:在这篇文章里,我们将一同检验一下对web form的一些改进。这样的改进很多,我们还将在随后的文章里体验更多这种改进。

Visual Studio 2010 Beta 1和.NET Framework Beta 1曾经发布有一段时间了,我也早就该写这篇文章了。ASP.NET 4.0改进了许多不同的场景集(set of scenarios),如Webforms ,Dynamic Data以及基于AJAX的Web开发。此外还有许多对支撑ASP.NET的核心运转时环境的改进,比如Caching, Session,还有Request/Response对象。

在这篇文章里,我们将一同检验一下对web form的一些改进。这样的改进很多,我们还将在随后的文章里体验更多这种改进。

使用ViewStateMode属性控制View State - 功用的加强

在ASP.NET Webform里最为人所诟病的毛病之一就是不断增多的viewstate影响到功用。虽然之前就可以把EnableViewState属性设为true或false ,之后,所以有的controls都默认承继,并且即便你在control层把它设为启用,也还是会产生不分歧的行为。

在ASP.NET 4.0中 , ViewStateMode属性有助于确定每个control的Viewstate能否应启用,禁用或被承继。例如:

<asp:Panel ID="pnlViewState" runat="server" ViewStateMode="Disabled">
      Disabled: <asp:Label ID="label1" runat="server"  Text="Value set in markup"ViewStateMode="Inherit"  /><br />
           Enabled: <asp:Label ID="label2"  runat="server" Text="Value set in markup"ViewStateMode="Enabled" />
  <hr />
  <asp:button ID="Button1" runat="server"  Text="Postback" />
    </asp:Panel>

后端代码

protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            label1.Text = "Value set in code behind";
            label2.Text = "Value set in code behind";
        }
    }

运转这个页面,你会发现两个标签的初值都被设为了"Value set in code behind",而点击按钮(postback)后,label1的值变成了“Value set in markup” ,label2的值则保持不变。正如你所看到的那样,保存这两个标签的面板把ViewStateMode设置为禁用,label1承继了这一设置(如果没有指定的话这是默认值),label2则设为了启用。这就是为什么label2保持了viewstate而label1丢失了。

虽然可以说之前就可以使用简便的EnableViewState属性,但不断就不稳定。想想我们在大多数功用讨论会(performance session)上,都会说如果viewstate不能正常运作就先禁用它然后再在control层设为启动,这个ViewStateMode的引入可以说是有助提升功用的一个很好的结构性变动(architectural change)。

网页的Meta Keyword和Description - 搜索引擎优化功用

在Visual Studio 2008中,可以通过直接声明或在程序中使用Page.Title设置网页的标题。随着越来越多的流量通过搜索引擎,网页的标题,关键字和描述变得更为重要了。虽然由于关键字被人滥用导致许多搜索引擎曾经对此忽略不计,但是,页面的描述还是Google,Bing这些主流搜索引擎赖以鉴别和索引网页内容的依据。

ASP.NET中的新功用4.0允许用户像下面这样通过编程的方式设置页面描述和关键词: -

protected void Page_Load(object sender, EventArgs e)
    {
        this.Page.Title = "My ASP.NET Blog";
        this.Page.MetaKeywords = "ASP.NET, Web Development, Blog, ASP.NET Blog";
        this.Page.MetaDescription = "This Blog contains posts related to ASP.NET and Web Development";
    }

以上代码会产生如下标记:

<meta name="keywords" content="ASP.NET, Web Development, Blog, ASP.NET Blog" />

<meta name="description" content="This Blog contains posts related to ASP.NET and Web Development" />

它的运作机制是,如果meta标签曾经出如今HTML标签里,那么只需name属性相反,程序中设定的内容就都会被填写到content里。

虽然这看起来很简单,但是在要依据某些条件或标准来动态设置它们的情况下,这就很有用了。目前,这些内容都是在HTML代码里静态地设定的。如今,有了Page类这一级的访问,它们就可以动态地设置了。

对Webforms还有许多其它的改进,比如Routing的加强,ClientID的设置等,我们将在后面的文章里逐一详解。

让我们喝彩吧!