TA的每日心情 | 衰 2019-8-18 09:37 |
---|
签到天数: 2 天 [LV.1]初来乍到
|
随着微软.NET的流行,ASP.NET越来越为广大开发人员所接受。作为ASP.NET的开发人员,我们不仅需要掌握其基 本的原理,更要多多实践,从实践中获取真正的开发本领。在我们的实际开发中,往往基本的原理满足不了开发需
7 ~" Q$ N& x$ q( f( u9 u9 U求,我们更多的要积累一些开发技巧,本文就向大家介绍一些实用技巧,希望对大家的开发有所裨益。* t0 q* u- ?2 d0 \1 g1 ?
1. ~ 的用法
1 w" t+ u1 b% E 一般的情况下,我们是使用./../ 这样的相对路径来确定和规划我们的资源(比如图片、资源文件),但这种方
4 B7 f Z& ^) l9 g$ Q式下在我们部署应用的时候,可能会出错,另外对于.ascx的控件中如果包含了一个图片,而这个控件被我们在不+ x0 V" d# M4 R; _6 ]/ Q8 a
同层次的两个目录的aspx文件分别引用时,问题就会出现了。2 {2 u$ H+ A; f1 N. b; I( R! N
~/image/about.bmp
& r# X3 f- e C& c是一种非常好的方法,它以Web应用程序的根目录为起始点,这样使得比你使用./image/about.bmp这样的方式要更 J g! ^: s5 @' f+ z+ s
加灵活和方便。有一点不好,是这种方式是在ASP.NET运行时动态解析的,所以在IDE设计模式中,你可能不能预览
5 s( D9 r! ?' m ~. R% Y它。- L' g8 o1 @8 g4 F1 z, s( m
2. 在刷新和提交页面后,保存你的页面滚动条的位置* w8 A" b, c' Q' G
经常有这样的情况,我们需要用户提交一个表单,但是表单中有超过500+个?控件或文本框要填写,也就是说( L% o0 f' E8 Z' T2 ^2 R' q
用户需要拉动IE的滚动条才能够填得完,那么假如用户正在可见IE范围的2/3处,选择了一个组合框的值,很不幸
/ R/ ^. Q( M$ e7 u组合框是服务器端的,那么也就意味着页面会提交一次,而当用户再看见刷新过的页面时,页面确定在3/1的地方
4 t* x# m2 s' K' L8 F3 k0 d$ f也就是显示在页面最开始的地方,用户只有拖动鼠标,然后接着刚刚的地方再填写剩下的250个控件,很不幸,370, U4 A7 [; o" z3 l \. ^1 B6 `
个控件又需要他选择一下? 4 T4 [* C5 N/ s. o
用下面的方法可以很快地确定和记住你提交前的位置。
/ ?, X) t# Y, w9 [ 网上的Old Dog Learns New Tricks也有一个类似的例子Maintain Scroll Position in any Page Element,
5 N6 d3 y. ~% W+ G' @4 l" u不过他使用了Web Behavior这意味着你需要使用一个.htc文件
) R( `" Q( j, N2 l" V0 CPrivate Sub RetainScrollPosition()7 k' X! B# C5 b2 }: n
Dim saveScrollPosition As New StringBuilder1 }6 w- m0 R! c6 ]) s
Dim setScrollPosition As New StringBuilder
4 p; r0 j; W8 I7 }: F( ^8 J0 {, pRegisterHiddenField("__SCROLLPOS", "0")
& r+ @) X+ U% V, _+ e/ A8 MsaveScrollPosition.Append("<script language='javascript'>")
2 r% V' ^. f9 U( b [9 z* h5 isaveScrollPosition.Append("function saveScrollPosition() {")5 T, G& f+ z% I# c. @0 ]3 ~3 t
saveScrollPosition.Append(" document.forms[0].__SCROLLPOS.value = document.body.scrollTop;")1 z5 z: v# o( V
saveScrollPosition.Append("}")9 \: d! E! j& o: T' z! n7 D
saveScrollPosition.Append("document.body.onscroll=saveScrollPosition;")( w: W9 F, P9 {' _
saveScrollPosition.Append("</script>")
- z. W! K; |* ~8 I, ERegisterStartupScript("saveScroll", saveScrollPosition.ToString())
9 ^3 a* P9 y" [2 C* K5 V' n) k/ QIf (Page.IsPostBack = True) Then
' ^' v" j; W2 X! e c9 qsetScrollPosition.Append("<script language='javascript'>")
* C5 [0 h }; b6 D; \/ jsetScrollPosition.Append("function setScrollPosition() {")
2 P$ U* q+ u% O8 `setScrollPosition.Append(" document.body.scrollTop = " & Request("__SCROLLPOS") & ";")3 k# c* @/ `) ?/ D9 ^$ e. v
setScrollPosition.Append("}")' f# N6 _6 j, w2 G
setScrollPosition.Append("document.body.onload=setScrollPosition;")8 e* O; Y8 y, n' Q4 a1 \ n/ I
setScrollPosition.Append("</script>"). L; u/ G$ f, R3 g$ e
RegisterStartupScript("setScroll", setScrollPosition.ToString())
7 H. @ Z7 t7 YEnd If
8 J9 }/ H* M' uEnd Sub) H& p/ U9 ? U$ \
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 3 R( y" ^$ }# C( O- W& a9 H
MyBase.Load* {5 b4 r% B* w5 ]' f
RetainScrollPosition()
( e4 p( n4 u# E* e+ fEnd Sub ( Z" I$ Z- k' s2 P0 N( @5 h" N
3 w0 q* p- x; T3. DataList使用不同风格的模板0 q: \! A9 Q$ `- |
这招也非常实用,你可以制作两个不同的模板或表现形式,分别以.ascx控件的形式保存,运行时根据某个条* x8 o4 x1 B/ H
件动态的选择使用其中的一个模板,另外ScottGu认为ItemDataBound方法也可以定制你显示的表现,比如加亮某个5 d3 w% ]# i# I+ Z( Y- |
元素或是加一个促销广告图等等。 {) n! b# x; s* q: W+ L0 J
Dim theme As String
8 _% f* D% E" Htheme = DropDownList1.SelectedValue% |2 [3 A. t' D* h* h1 v
DataList1.ItemTemplate = Page.LoadTemplate(theme & ".ascx") ---Cool
e7 u, e; V% l+ A" j3 kDataList1.DataSource = DS
7 ?! g0 p' ~) d3 |4 t% UDataList1.DataBind()
4 n0 o+ P+ {$ C9 M. k 4. 设置服务器端控件的焦点- |. g. z3 ]- E8 T& P0 P- R
Private Sub SetFocus(ByVal controlToFocus As Control)
. ]( S$ F1 n1 {# c) v: r1 Q7 WDim scriptFunction As New StringBuilder
, _* S. p1 c8 _2 A( _- y( ^Dim scriptClientId As String1 W _1 c" j4 L( d
scriptClientId = controlToFocus.ClientID0 G/ Z$ A. X2 v: o9 Y& ~' H' H. D1 D
scriptFunction.Append("<script language='javascript'>")
9 t3 ?# d% k) o4 E+ J4 LscriptFunction.Append("document.getElementById('" & scriptClientId & "').focus();")
) i: k( n7 `4 O8 AscriptFunction.Append("</script>")$ Q3 N1 Y) z, `2 w/ r
RegisterStartupScript("focus", scriptFunction.ToString())
# O6 x. H& ~ z; |6 O9 HEnd Sub8 i* k, D% \* q9 q+ r3 C" X; ~( `& {& P
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 7 O" a& Z; o3 F) s: v
MyBase.Load( J1 [0 M( {" X
If (Page.IsPostBack = False) Then1 G" M7 Z9 C- E6 U! C) P, ^, J
SetFocus(TextBox1)
# V3 o; z5 g0 xEnd If" j- l: K. D/ o! Z9 W) b
End Sub
; f4 Z. }2 m$ |% f8 |2 u 5. 滚动DataGrid
6 r; m& j- O$ E 这招就更简单了,有时候你的页面只有一个固定的地方,但是需要显示非常多的数据,亦或是也不定,但是只
! r! s. n: }% `; d8 K有固定的一个地方给你显示它了。这时你就可以用下面这招,自动出滚动条,而且适用许多控件。很简单将你的控
5 |/ [( Q0 P6 V* ?件放在一个DIV中将overflow属性设置成auto; e1 Z4 d8 v' ~2 ~" b
<div style=“height:400px;width:200px;overflow:auto”>
9 y2 a6 G( u( C8 S' T2 Y<asp:datagrid id=“MyGrid” runat=“server”/>
& m" k; L* `" u `, V</div> & b' }- W/ s% _' G
6. 动态创建控件
6 D. s/ N" e4 N; a" ? 利用PlaceHolder控件,这东西在ASP.NET 2.0 Mutil-View和Master Page中运用的就更加多了。
. c% q9 m5 `' ]& @+ Z( P( CSub Page_Load()/ w( |4 J [5 k7 O$ F
Dim i as Integer
' m% _* ^5 `( i$ ~+ J! {+ i: JFor i=0 to 4 % o/ ?! Z: Z# t2 ]( i
Dim myUserControl as Control
8 |9 E8 i0 ?2 amyUserControl = Page.LoadControl(“foo.ascx”): |" a Q" A9 s3 _. N' v
PlaceHolder1.Controls.Add(myUserControl); Z! G( t, w3 J; H: F
PlaceHolder1.Controls.Add(New LiteralControl(“<br>”))2 b' Y) x5 s" R* s+ |
Next i
4 t# U4 U" O) J4 J# R/ t( H" a2 e: z; CEnd Sub
2 I; `" n7 }6 }. J+ ?: v! @ 7. 客户端代码的使用
* \* J/ B0 N9 c3 y# }# o 1). 可以使用客户端的事件代码,但两者不能同名,服务器端代码的名是你可以控制的。对于非ASP.NET的标
, ^6 [* t2 ?/ a& Z准控件的自定义控件必须实现IAttributeAccessor接口或从WebControl派生并且可用expando属性1 L; ~. }, b8 c& E Z
asp:ImageButton id=“foo” - b5 ^, v" r5 z; [
ImageUrl=“start.jpg”
. S/ j' A7 N# s3 M. C/ P1 UonMouseOver=“rollover(this);”
- u* ~& q7 e) o% JonMouseOut=“rollout(this)”! b% \& P2 Q' }6 P9 }9 ~) z0 m1 s
rolloversrc=“myrollover.jpg”& H& j8 x# X) H1 E8 F+ Z1 M
rolloutsrc=“myrollout.jpg”
1 v% g- s2 f& J, _" Prunat=“server”/>
: S, ]# D. q. f5 \& G<input type=Button onClick=“return clientHandler()” 0 T1 D* j' x' X$ |8 f% V, J! F0 J2 s
onServerClick=“Button1_Click” … /> : L* |& [$ D. y
2). 使用可以在Postback之前执行客户端代码,当然也可以取消这次Postback,另外也可以访问客户端该页所' I' t1 X4 Q d7 |% M
有的客户端控件。
: C1 X$ E. c& o6 r* TPrivate Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 3 C% T! u' l6 [0 w
MyBase.Load ]' j U- e& Q9 l6 S
RegisterOnSubmitStatement("foo", "return confirm('Are you sure you want to submit the order?');")8 _5 m, }' N K. H6 B, [+ I# `# `2 R& g
End Sub 6 i, o! _! q: Y1 H
3). 还有更复杂的我认为不实用,大家可以自己去看,主要是运用RegisterStartupScript和JavaScript的技术 |
|