閱讀689 返回首頁    go 阿裏雲 go 技術社區[雲棲]


設計ASP.NET應用程序的七大絕招

隨著微軟.NET的流行,ASP.NET越來越為廣大開發人員所接受。作為ASP.NET的開發人員,我們不僅需要掌握其基本的原理,更要多多實踐,從實踐中獲取真正的開發本領。在我們的實際開發中,往往基本的原理滿足不了開發需求,我們更多的要積累一些開發技巧,本文就向大家介紹一些實用技巧,希望對大家的開發有所裨益。

1.~的用法

一般的情況下,我們是使用./../這樣的相對路徑來確定和規劃我們的資源(比如圖片、資源文件),但這種方式下在我們部署應用的時候,可能會出錯,另外對於.ascx的控件中如果包含了一個圖片,而這個控件被我們在不同層次的兩個目錄的aspx文件分別引用時,問題就會出現了。

~/image/about.bmp是一種非常好的方法,它以Web應用程序的根目錄為起始點,這樣使得比你使用./image/about.bmp這樣的方式要更加靈活和方便。有一點不好,是這種方式是在ASP.NET運行時動態解析的,所以在IDE設計模式中,你可能不能預覽它。

2.在刷新和提交頁麵後,保存你的頁麵滾動條的位置

經常有這樣的情況,我們需要用戶提交一個表單,但是表單中有超過500+個?控件或文本框要填寫,也就是說用戶需要拉動IE的滾動條才能夠填得完,那麼假如用戶正在可見IE範圍的2/3處,選擇了一個組合框的值,很不幸組合框是服務器端的,那麼也就意味著頁麵會提交一次,而當用戶再看見刷新過的頁麵時,頁麵確定在3/1的地方也就是顯示在頁麵最開始的地方,用戶隻有拖動鼠標,然後接著剛剛的地方再填寫剩下的250個控件,很不幸,370個控件又需要他選擇一下?

用下麵的方法可以很快地確定和記住你提交前的位置。

網上的OldDogLearnsNewTricks也有一個類似的例子MaintainScrollPositioninanyPageElement,不過他使用了WebBehavior這意味著你需要使用一個.htc文件

PrivateSubRetainScrollPosition()

DimsaveScrollPositionAsNewStringBuilder
DimsetScrollPositionAsNewStringBuilder

RegisterHiddenField("__SCROLLPOS","0")
saveScrollPosition.Append("<scriptlanguage='javascript'>")
saveScrollPosition.Append("functionsaveScrollPosition(){")
saveScrollPosition.Append("document.forms[0].__SCROLLPOS.value=thebody.scrollTop;")
saveScrollPosition.Append("}")
saveScrollPosition.Append("thebody.onscroll=saveScrollPosition;")
saveScrollPosition.Append("</script>")

RegisterStartupScript("saveScroll",saveScrollPosition.ToString())

If(Page.IsPostBack=True)Then

setScrollPosition.Append("<scriptlanguage='javascript'>")
setScrollPosition.Append("functionsetScrollPosition(){")
setScrollPosition.Append("thebody.scrollTop="&Request("__SCROLLPOS")&";")
setScrollPosition.Append("}")
setScrollPosition.Append("thebody.onload=setScrollPosition;")
setScrollPosition.Append("</script>")
RegisterStartupScript("setScroll",setScrollPosition.ToString())

EndIf

EndSub

PrivateSubPage_Load(ByValsenderAsSystem.Object,ByValeAsSystem.EventArgs)HandlesMyBase.Load
RetainScrollPosition()
EndSub
3.DataList使用不同風格的模板

這招也非常實用,你可以製作兩個不同的模板或表現形式,分別以.ascx控件的形式保存,運行時根據某個條件動態的選擇使用其中的一個模板,另外ScottGu認為ItemDataBound方法也可以定製你顯示的表現,比如加亮某個元素或是加一個促銷廣告圖等等。

DimthemeAsString
theme=DropDownList1.SelectedValue

DataList1.ItemTemplate=Page.LoadTemplate(theme&".ascx")---Cool
DataList1.DataSource=DS
DataList1.DataBind()

4.設置服務器端控件的焦點

PrivateSubSetFocus(ByValcontrolToFocusAsControl)
DimscriptFunctionAsNewStringBuilder
DimscriptClientIdAsString

scriptClientId=controlToFocus.ClientID
scriptFunction.Append("<scriptlanguage='javascript'>")
scriptFunction.Append("document.getElementById('"&scriptClientId&"').focus();")
scriptFunction.Append("</script>")
RegisterStartupScript("focus",scriptFunction.ToString())
EndSub

PrivateSubPage_Load(ByValsenderAsSystem.Object,ByValeAsSystem.EventArgs)HandlesMyBase.Load
If(Page.IsPostBack=False)Then
SetFocus(TextBox1)
EndIf
EndSub

5.滾動DataGrid

這招就更簡單了,有時候你的頁麵隻有一個固定的地方,但是需要顯示非常多的數據,亦或是也不定,但是隻有固定的一個地方給你顯示它了。這時你就可以用下麵這招,自動出滾動條,而且適用許多控件。很簡單將你的控件放在一個DIV中將overflow屬性設置成auto

<divstyle=“height:400px;width:200px;overflow:auto”>
<asp:datagridid=“MyGrid”runat=“server”/>
</div>

6.動態創建控件

利用PlaceHolder控件,這東西在ASP.NET2.0Mutil-View和MasterPage中運用的就更加多了。

SubPage_Load()
DimiasInteger
Fori=0to4
DimmyUserControlasControl
myUserControl=Page.LoadControl(“foo.ascx”)
PlaceHolder1.Controls.Add(myUserControl)
PlaceHolder1.Controls.Add(NewLiteralControl(“<br>”))
Nexti
EndSub

7.客戶端代碼的使用

1).可以使用客戶端的事件代碼,但兩者不能同名,服務器端代碼的名是你可以控製的。對於非ASP.NET的標準控件的自定義控件必須實現IAttributeAccessor接口或從WebControl派生並且可用expando屬性

asp:ImageButtonid=“foo”
ImageUrl=“start.jpg”
onMouseOver=“rollover(this);”
onMouseOut=“rollout(this)”
rolloversrc=“myrollover.jpg”
rolloutsrc=“myrollout.jpg”
runat=“server”/>

<inputtype=ButtononClick=“returnclientHandler()”
onServerClick=“Button1_Click”…/>

2).使用可以在Postback之前執行客戶端代碼,當然也可以取消這次Postback,另外也可以訪問客戶端該頁所有的客戶端控件。

PrivateSubPage_Load(ByValsenderAsSystem.Object,ByValeAsSystem.EventArgs) HandlesMyBase.Load
 RegisterOnSubmitStatement("foo","returnconfirm('Areyousureyouwanttosubmittheorder?');")
EndSub

3).還有更複雜的我認為不實用,大家可以自己去看,主要是運用RegisterStartupScript和JavaScript的技術

以上文章介紹了一些ASP.NET中常用而且比較實用的技巧,希望能對大家的實際開發有所裨益!

最後更新:2017-04-02 00:06:33

  上一篇:go 在asp.net中為Web用戶控件添加屬性和事件
  下一篇:go 使用.NET實現斷點續傳