TA的每日心情 | 衰 2019-8-18 09:37 |
---|
签到天数: 2 天 [LV.1]初来乍到
|
随着微软.NET的流行,ASP.NET越来越为广大开发人员所接受。作为ASP.NET的开发人员,我们不仅需要掌握其基 本的原理,更要多多实践,从实践中获取真正的开发本领。在我们的实际开发中,往往基本的原理满足不了开发需
$ J- _$ C Y! J! i6 M6 g求,我们更多的要积累一些开发技巧,本文就向大家介绍一些实用技巧,希望对大家的开发有所裨益。
/ X& s* g/ r+ U" z! M6 a3 f) O 1. ~ 的用法; K. w; I) [$ E% ^3 Y
一般的情况下,我们是使用./../ 这样的相对路径来确定和规划我们的资源(比如图片、资源文件),但这种方5 i3 z+ i X$ V$ ^
式下在我们部署应用的时候,可能会出错,另外对于.ascx的控件中如果包含了一个图片,而这个控件被我们在不: X- Y$ `. M, J9 h7 N
同层次的两个目录的aspx文件分别引用时,问题就会出现了。. `1 [0 _3 n; A7 h" z" F) M
~/image/about.bmp
! o* l+ d' }4 Z' J7 `% ^7 S是一种非常好的方法,它以Web应用程序的根目录为起始点,这样使得比你使用./image/about.bmp这样的方式要更! u! ~4 B2 m9 |* j2 n$ P
加灵活和方便。有一点不好,是这种方式是在ASP.NET运行时动态解析的,所以在IDE设计模式中,你可能不能预览- ^& z9 k& y- D" c- Y$ k) E
它。
4 t+ e" P" a* G) ^9 L8 ~ 2. 在刷新和提交页面后,保存你的页面滚动条的位置& H9 l# @) X( _% z J
经常有这样的情况,我们需要用户提交一个表单,但是表单中有超过500+个?控件或文本框要填写,也就是说
+ ~( u7 N+ C9 ~4 x3 A用户需要拉动IE的滚动条才能够填得完,那么假如用户正在可见IE范围的2/3处,选择了一个组合框的值,很不幸
+ k$ E" Y" n7 U3 ]/ v* r" ^ R3 `组合框是服务器端的,那么也就意味着页面会提交一次,而当用户再看见刷新过的页面时,页面确定在3/1的地方+ C- |5 ~. ~2 j6 }# |. A
也就是显示在页面最开始的地方,用户只有拖动鼠标,然后接着刚刚的地方再填写剩下的250个控件,很不幸,370
e; \" |& T, O/ J! w# s个控件又需要他选择一下?
/ B8 x, V# I0 m! u5 U5 v5 B8 d 用下面的方法可以很快地确定和记住你提交前的位置。
! L1 Q; e1 R8 }+ M4 O 网上的Old Dog Learns New Tricks也有一个类似的例子Maintain Scroll Position in any Page Element,
) r& i$ I- j/ H5 M; O/ w不过他使用了Web Behavior这意味着你需要使用一个.htc文件( e2 _" X; B4 H$ `. s. T. {3 q
Private Sub RetainScrollPosition()
8 u% C. }' d! N9 |6 iDim saveScrollPosition As New StringBuilder. l2 y+ ]; E& H. f8 {' k" k5 l
Dim setScrollPosition As New StringBuilder
( Q' S- E: H% L* z a8 o+ w( s& qRegisterHiddenField("__SCROLLPOS", "0")
' l) K) B2 z- s4 ^' g. v, `saveScrollPosition.Append("<script language='javascript'>")
/ R& l0 G) e" J! y( E( A6 ssaveScrollPosition.Append("function saveScrollPosition() {"), |' q+ ]$ C" N5 J* y) y) l
saveScrollPosition.Append(" document.forms[0].__SCROLLPOS.value = document.body.scrollTop;")# |0 |. D! h5 F7 F; _
saveScrollPosition.Append("}")1 h8 V) `% U3 r6 D
saveScrollPosition.Append("document.body.onscroll=saveScrollPosition;")
: i7 A$ o) I1 F7 j! I4 v( nsaveScrollPosition.Append("</script>")# ], ^9 q3 _: J: L8 ^1 \. M% @
RegisterStartupScript("saveScroll", saveScrollPosition.ToString())" y1 f' F' G& W. F6 \5 V* |6 Q
If (Page.IsPostBack = True) Then
! l* D4 p9 `5 k# j1 S2 Y+ k3 K& c9 k+ gsetScrollPosition.Append("<script language='javascript'>")
2 o( p4 X" p6 `setScrollPosition.Append("function setScrollPosition() {")
) }3 G2 A, O' D9 J: [0 F. R! V' VsetScrollPosition.Append(" document.body.scrollTop = " & Request("__SCROLLPOS") & ";")
- g# R; ]* r F( Q, FsetScrollPosition.Append("}")
2 ?, U9 J( Q5 B. f! EsetScrollPosition.Append("document.body.onload=setScrollPosition;")8 J1 G8 x5 B" u& u4 N1 k
setScrollPosition.Append("</script>")
6 }9 ^5 ]& \4 ERegisterStartupScript("setScroll", setScrollPosition.ToString())/ o2 P; M0 L$ z+ i8 c
End If
' v% b* T4 o7 pEnd Sub9 @. ^, K; x6 {* ^2 a
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles
" K1 D a1 [/ e: U# p1 E* I- HMyBase.Load* O# g- |) `" v9 X+ N4 ~6 J0 v
RetainScrollPosition()* }# T. G3 t1 x/ n5 u6 F
End Sub
: Y( U4 E9 `0 u, z' J: I0 t8 ~% Z( k4 c$ F
3. DataList使用不同风格的模板# Q( M) b# V) ?* g; N
这招也非常实用,你可以制作两个不同的模板或表现形式,分别以.ascx控件的形式保存,运行时根据某个条. ] B& {* _% x0 q t( v
件动态的选择使用其中的一个模板,另外ScottGu认为ItemDataBound方法也可以定制你显示的表现,比如加亮某个! V. b7 S/ S! ]% O5 U0 g( v+ i
元素或是加一个促销广告图等等。
7 [3 Y7 l+ n/ d+ a% b6 b5 e; h% ZDim theme As String
2 ~7 d& Q. L z; {5 g6 xtheme = DropDownList1.SelectedValue) e% @; P, W K& V3 p
DataList1.ItemTemplate = Page.LoadTemplate(theme & ".ascx") ---Cool
, |. `8 x1 l- k) ]; D# j+ a* hDataList1.DataSource = DS8 R* Z3 S/ C. w. m9 ?
DataList1.DataBind() . Z. Z$ ]' U* _' _% _3 J7 R
4. 设置服务器端控件的焦点
8 u, W: m, j; o2 S3 _Private Sub SetFocus(ByVal controlToFocus As Control)) W8 U R+ t- Y4 V
Dim scriptFunction As New StringBuilder/ o. w! q1 c. p! Q4 y: {$ C: l# K8 X3 Z
Dim scriptClientId As String# z' x. }. A2 m" E* A! | g
scriptClientId = controlToFocus.ClientID {) q4 z: \8 j; p: S
scriptFunction.Append("<script language='javascript'>"): J/ P6 U' E/ M
scriptFunction.Append("document.getElementById('" & scriptClientId & "').focus();")
9 |1 W: q! p( {% C: x$ ]. y* a/ MscriptFunction.Append("</script>")
7 [" f# R: C3 ?7 t- v/ JRegisterStartupScript("focus", scriptFunction.ToString())
1 Q# G& c) ^7 I. qEnd Sub& z9 N/ C/ F) d) u2 M
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 2 @0 D' g' H* X
MyBase.Load
$ V% s/ ~3 n' O1 c; A7 XIf (Page.IsPostBack = False) Then
+ K/ H3 l O1 P$ X) USetFocus(TextBox1)
. {# N W$ e) h- {/ QEnd If
6 X% T9 a7 G" o+ @End Sub - m/ D& x. q. Q1 q
5. 滚动DataGrid
4 W& x) y% I: b: H 这招就更简单了,有时候你的页面只有一个固定的地方,但是需要显示非常多的数据,亦或是也不定,但是只
* l3 s# L8 A0 H# R9 n# U% j. n有固定的一个地方给你显示它了。这时你就可以用下面这招,自动出滚动条,而且适用许多控件。很简单将你的控$ ]+ m/ a- r' i M. Y2 \
件放在一个DIV中将overflow属性设置成auto5 Q; i$ i P0 _6 I- f' t0 N
<div style=“height:400px;width:200px;overflow:auto”>
( ], D- P" a7 @! G) d<asp:datagrid id=“MyGrid” runat=“server”/>- u* `2 n# P* |0 I
</div> 0 q7 O `. o9 B; D' H* Q
6. 动态创建控件
( ?/ X3 b1 D F8 i' l" ] ] 利用PlaceHolder控件,这东西在ASP.NET 2.0 Mutil-View和Master Page中运用的就更加多了。
7 O$ r4 I" B$ }7 t/ j$ xSub Page_Load()' y# g% s, d9 y2 X8 A& p
Dim i as Integer$ ]! d/ P8 O S, j; m$ W
For i=0 to 4 ) W# G" R i6 b4 Z1 d; X
Dim myUserControl as Control. {1 E5 ?5 D: ^( o
myUserControl = Page.LoadControl(“foo.ascx”)
, }& S/ p( [8 Y# h3 QPlaceHolder1.Controls.Add(myUserControl)
' Q# h! Z7 [) T6 PPlaceHolder1.Controls.Add(New LiteralControl(“<br>”))9 |* X. S7 ^5 l9 O' E5 S
Next i3 d6 S0 l5 q# p/ z# w
End Sub $ s5 Q! m5 h* A, n/ ?
7. 客户端代码的使用- @" M. [9 e+ O6 Z
1). 可以使用客户端的事件代码,但两者不能同名,服务器端代码的名是你可以控制的。对于非ASP.NET的标
/ J: [; O% `+ _ y: ]准控件的自定义控件必须实现IAttributeAccessor接口或从WebControl派生并且可用expando属性
5 a6 ^$ B9 D* j8 {; g+ R3 @) `asp:ImageButton id=“foo”
3 t3 h6 ~4 p" ]1 t+ ]8 S0 fImageUrl=“start.jpg”
! p! f2 B) }: VonMouseOver=“rollover(this);”
5 \# t6 O# ~* j+ G7 [1 Y2 IonMouseOut=“rollout(this)”* |9 q D5 I/ a4 f
rolloversrc=“myrollover.jpg”+ m( o H) O' Z# Q* I
rolloutsrc=“myrollout.jpg”
; N" Q" ?4 ]- y( krunat=“server”/>6 H/ n" Q5 J; k: D5 A7 l9 I
<input type=Button onClick=“return clientHandler()”
% G/ ]8 f$ B& q6 WonServerClick=“Button1_Click” … />
/ K. p' H( v# J2 e# D' K 2). 使用可以在Postback之前执行客户端代码,当然也可以取消这次Postback,另外也可以访问客户端该页所% E @' }7 D& d# s, g
有的客户端控件。
1 L' j0 |/ Y1 b& C- |9 V$ hPrivate Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles
5 }; q$ F( R5 Z: O/ GMyBase.Load
2 J% o" c+ I. D RegisterOnSubmitStatement("foo", "return confirm('Are you sure you want to submit the order?');") m" Q- Y o2 O' |
End Sub
( I6 ~" ~5 C2 D6 ]9 _& x7 o 3). 还有更复杂的我认为不实用,大家可以自己去看,主要是运用RegisterStartupScript和JavaScript的技术 |
|