一些简单的ASP.NET 2.0技巧

17 篇文章 0 订阅
16 篇文章 0 订阅
 
1 、在CallBack之后保持滚动条的位置
Asp.Net1.1 中, CallBack 之后保持滚动条的位置是一件非常痛苦的事情,特别是页中有一个 Grid 并且想要编辑特定的行。为了不停留在想要得行,页面会重新加载并且必须在顶部向下滚动。在 Asp2.0 中,只需要简单的在页面的属性中加入MaintainScrollPostionOnPostBack属性即可:
2、页面加载后设置默认焦点到控件上
这也是一个非常简单的例子,不需要javascript的辅助即可完成。如果在页面中有一两个textbox,为什么要让用户去点击textbox来开始输入数据呢?是不是可以能够让光标已经停留在textbox进而可以输入数据呢?使用HtmlForm控件的DefaultFocus属性就可以轻易的做到:
< form  id ="frm"  DefaultFocus ="txtUserName"  runat ="server" >
    
   </ form >

3、用户点击“Enter”键时触发默认按钮的click实践。
在Asp1.1中,想要使用户点击“Enter”键就能关联到一个button的服务器段的click事件需要借助于javascript,这是很痛苦的。幸好,现在可你使用HtmlForm控件的DefaultButton属性来设置。这个属性也可以设置到Panel控件上,当用户移动到页面中不同的Panel上,点击enter键来触发不同的button控件的click事件。
   < form  id ="frm"  DefaultButton ="btnSubmit"  runat ="server" >
     
   </ form >

4、简单的寻找固定的控件。
在页面的控件中按层次寻找控件很痛苦,但是如果你知道控件怎样固定在页面中,就可以用简写”$”来查找控件而不用写递归的代码。请看下面代码,注意”$”的使用:
< form  id ="form1"  runat ="server"  DefaultFocus ="formVw$txtName" >
    
< div >
        
< asp:FormView  ID ="formVw"  runat ="server" >
            
< ItemTemplate >
                Name: 
                
< asp:TextBox  ID ="txtName"  runat ="server"  
                    Text
='<%#  Eval("FirstName") + " " + Eval("LastName") % > ' />
            
</ ItemTemplate >
        
</ asp:FormView >
    
</ div >
</ form >
这个小技巧也可以用在服务器端的 使用 FindControl() 函数时:
TextBox tb = this.FindControl("form1$formVw$txtName") as TextBox;
if (tb != null)
{
    //Access TextBox control


5、强类型访问跨页提交的控件
这个比其他的要内容多一点,但是很有用。 ASP.NET 2.0引入了交叉回发的概念使得一个页面可以将信息回发到另一个不同的页面,可以将button控件的PostBackUrl属性设置为接受回发数据的页面来完成。一般的,回发的数据可以象前一页那样做一些事情。但是,如果你要获得前一页制定控件的属性就需要一个cast(),如果你给引起回发的code-behide页面添加了一个公共属性,你就可以直接以强类型的方式添加PreviousPageType来指向引起回发的页面从而能够访问那个属性。
如果有一个页面 Default.aspx,他有一个公共属性来返回此页面上一个TextBox,数据回发目的页(SearchResults.aspx)可以以强类型的方式(不需要FindControl() 方法),在页面的顶部添加:
<% @ PreviousPageType VirtualPath = " Default.aspx "  %> 
这样, SearchResults.aspx中代码就可以以强类型的方式访问Default.aspx的TextBox。下面的例子假定Default.aspx定义的属性名为SearchTextBox:
TextBox tb  =  PreviousPage.SearchTextBox; 
PreviousPageType还有一个TypeName属性,你可以定义一个基本类型,一个或多个页面从此类型继承下来,使得这种技术可以在多页面上使用。PreviousPage.IsCrossPagePostBack可以判断是否为垮页提交。
对于跨页提交的补充:
在 ASP.NET 1.X 版本中,页面都是提交到自己本身,并不能方便的指定需要提交的目的页面。例如FirstPage.aspx中的button只能提交到 FirstPage.aspx,而不能提交到SecondPage.aspx。很多时候,ASP.NET 1.X这样工作方式使我们的开发方式受到不少限制。熟悉ASP/JSP/PHP的朋友大概很不习惯,因为以前经常使用的提交方式突然无法使用,虽然也有解决这个问题的方法(欲详细了解的读者可去微软网站收看webcast),可是过程太烦琐,不甚方便。令我们高兴的是,ASP.NET 2.0中有了跨页面提交的简单方法。可在第一个页面中的button添加PostBackUrl属性设置为接受提交的页面,并且这个页面增加PreviousPageType 指令,若要是目标页面在新窗口中打开则可以在源页面<form>标记增加target=’_blank’属性。
<% @ Page Language = " C# "  MaintainScrollPositionOnPostback = " true "  AutoEventWireup = " true "  CodeFile = " "  Inherits = " "  %>

6、强类型访问母版页的控件
PreviousPageType指令并不是唯一的可以强类型访问控件的方法。如果在母版页中定义了一个公共属性,并且想要以强类型的方式访问它,那么就可以在页面顶部添加MasterType指令(注意:MasterType指令同PreviousPageType一样允许定义一个TypeName)
<% @ MasterType VirtualPath = " MasterPage.master "  %> 
你可以在内容页书写如下的代码来访问目标母版页的属性:
this .Master.HeaderText  =  " Label updated using MasterType directive with VirtualPath attribute. "
7、Validation groups验证组
一个页中可能有多个控件和多个按钮。当其中的一个按钮被点击后想要特定的 validator被激发而不是页面中的所有validator。在ASP.NET 1.1中除了hack code没有更好的办法。ASP.NET 2.0中给所有的validator控件和按钮(button、linkbutton等等)增加了ValidatorGroup属性,就可以轻松地解决这个问题。如果在页面中有一个TextBox并且紧挨着他有一个RequiredFieldValidator 和Button控件,可以将RequiredFieldValidator和Button的ValidationGroup属性设置成一样的值从而使得点击button时只触发这个RequiredFieldValidator的validor,任何没有定义在ValidationGroup内的其他的validator都会被忽略。看下例:
< form  id ="form1"  runat ="server" >
    Search Text: 
< asp:TextBox  ID ="txtSearch"  runat ="server"  />  
                    < asp:RequiredFieldValidator  ID ="valSearch"  runat ="Server"  
     ControlToValidate
="txtSearch"  ValidationGroup ="SearchGroup"  />  
                   
< asp:Button  ID ="btnSearch"  runat ="server"  Text ="Search"
         ValidationGroup
="SearchGroup"  />   .
        Other controls with validators and buttons defined here
</ form >

 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值