html5中文学习网

您的位置: 首页 > 网络编程 > ASP.NET » 正文

ASP.NET4.0新改进和新特性_.NET教程_编程技术

[ ] 已经帮助:人解决问题
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的一些改进。这样的改进很多,我们还将在随后的文章里体验更多这种改进。8eWHTML5中文学习网 - HTML5先行者学习网

使用ViewStateMode属性控制View State - 性能的增强8eWHTML5中文学习网 - HTML5先行者学习网

在ASP.NET Webform里最为人所诟病的毛病之一就是不断增多的viewstate影响到性能。尽管之前就可以把EnableViewState属性设为true或false ,之后,所以有的controls都默认继承,并且即使你在control层把它设为启用,也还是会产生不一致的行为。8eWHTML5中文学习网 - HTML5先行者学习网

在ASP.NET 4.0中 , ViewStateMode属性有助于确定每个control的Viewstate是否应启用,禁用或被继承。例如:8eWHTML5中文学习网 - HTML5先行者学习网

<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>8eWHTML5中文学习网 - HTML5先行者学习网

后端代码8eWHTML5中文学习网 - HTML5先行者学习网

protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            label1.Text = "Value set in code behind";
            label2.Text = "Value set in code behind";
        }
    }8eWHTML5中文学习网 - HTML5先行者学习网

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

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

网页的Meta Keyword和Description - 搜索引擎优化功能8eWHTML5中文学习网 - HTML5先行者学习网

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

ASP.NET中的新功能4.0允许用户像下面这样通过编程的方式设置页面描述和关键词: -8eWHTML5中文学习网 - HTML5先行者学习网

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";
    }8eWHTML5中文学习网 - HTML5先行者学习网

以上代码会产生如下标记:8eWHTML5中文学习网 - HTML5先行者学习网

<meta name="keywords" content="ASP.NET, Web Development, Blog, ASP.NET Blog" />8eWHTML5中文学习网 - HTML5先行者学习网

<meta name="description" content="This Blog contains posts related to ASP.NET and Web Development" />8eWHTML5中文学习网 - HTML5先行者学习网

它的运作机制是,如果meta标签已经出现在HTML标签里,那么只要name属性相同,程序中设定的内容就都会被填写到content里。8eWHTML5中文学习网 - HTML5先行者学习网

虽然这看起来很简单,但是在要根据某些条件或标准来动态设置它们的情况下,这就很有用了。目前,这些内容都是在HTML代码里静态地设定的。现在,有了Page类这一级的访问,它们就可以动态地设置了。8eWHTML5中文学习网 - HTML5先行者学习网

对Webforms还有许多其它的改进,比如Routing的增强,ClientID的设置等,我们将在后面的文章里一一详解。8eWHTML5中文学习网 - HTML5先行者学习网

让我们欢呼吧!
 8eWHTML5中文学习网 - HTML5先行者学习网

8eWHTML5中文学习网 - HTML5先行者学习网
8eWHTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助