TA的每日心情 | 衰 2019-8-18 09:37 |
|---|
签到天数: 2 天 [LV.1]初来乍到
|
随着微软.NET的流行,ASP.NET越来越为广大开发人员所接受。作为ASP.NET的开发人员,我们不仅需要掌握其基 本的原理,更要多多实践,从实践中获取真正的开发本领。在我们的实际开发中,往往基本的原理满足不了开发需
1 q6 v4 ~1 S0 ~ Z求,我们更多的要积累一些开发技巧,本文就向大家介绍一些实用技巧,希望对大家的开发有所裨益。8 V; [% q/ U8 o5 V; f
1. ~ 的用法& I u% L5 [% U0 Z" t' C; o* X
一般的情况下,我们是使用./../ 这样的相对路径来确定和规划我们的资源(比如图片、资源文件),但这种方
, L5 Z! s/ d. b$ ]/ J) P) C式下在我们部署应用的时候,可能会出错,另外对于.ascx的控件中如果包含了一个图片,而这个控件被我们在不
( h6 l' b5 g. S3 a9 u同层次的两个目录的aspx文件分别引用时,问题就会出现了。- b/ V$ f) {2 y, A: @
~/image/about.bmp
$ |7 W1 I5 U5 w) s* J是一种非常好的方法,它以Web应用程序的根目录为起始点,这样使得比你使用./image/about.bmp这样的方式要更
' |" Z! A0 [ S# [8 B/ _加灵活和方便。有一点不好,是这种方式是在ASP.NET运行时动态解析的,所以在IDE设计模式中,你可能不能预览
) e$ \$ j/ {( M( @1 N' q它。
( R7 i: @, W% ?0 s$ |- J. S) M 2. 在刷新和提交页面后,保存你的页面滚动条的位置5 }& Y- P) y6 y9 T6 Z8 G
经常有这样的情况,我们需要用户提交一个表单,但是表单中有超过500+个?控件或文本框要填写,也就是说: w$ y* g C( r& q1 b8 @2 G
用户需要拉动IE的滚动条才能够填得完,那么假如用户正在可见IE范围的2/3处,选择了一个组合框的值,很不幸
' O* q0 I. v& d1 x, ], i组合框是服务器端的,那么也就意味着页面会提交一次,而当用户再看见刷新过的页面时,页面确定在3/1的地方
, Y; ~$ T" E' r也就是显示在页面最开始的地方,用户只有拖动鼠标,然后接着刚刚的地方再填写剩下的250个控件,很不幸,3700 h! M8 s5 K: b. K$ p
个控件又需要他选择一下?
8 g9 c8 T0 s% ~5 O" ` 用下面的方法可以很快地确定和记住你提交前的位置。, e. d+ u) M7 V
网上的Old Dog Learns New Tricks也有一个类似的例子Maintain Scroll Position in any Page Element,8 o6 ?' Y; I9 u! K# @5 n) C- D
不过他使用了Web Behavior这意味着你需要使用一个.htc文件8 q. A7 |9 p3 I3 |% y4 h D
Private Sub RetainScrollPosition(). f% L3 f3 h( U
Dim saveScrollPosition As New StringBuilder
( [1 P2 j! [7 E8 ADim setScrollPosition As New StringBuilder8 d! P0 U! j1 s+ _2 U
RegisterHiddenField("__SCROLLPOS", "0")
% u4 w2 ~2 o) G0 UsaveScrollPosition.Append("<script language='javascript'>")7 `) W5 d( C' l& |/ i$ ]. W) o
saveScrollPosition.Append("function saveScrollPosition() {") @/ y- S) F+ \1 R) c% [& G
saveScrollPosition.Append(" document.forms[0].__SCROLLPOS.value = document.body.scrollTop;")( T# q& S" z& [3 {" r$ ]
saveScrollPosition.Append("}")9 Y7 ^3 O' t/ U2 N/ S6 W
saveScrollPosition.Append("document.body.onscroll=saveScrollPosition;")
/ b4 d2 m+ F9 G- I# B* y- MsaveScrollPosition.Append("</script>")
3 M' E* h0 j1 N( F4 C6 cRegisterStartupScript("saveScroll", saveScrollPosition.ToString())2 C$ {! L8 a; F2 @4 ^
If (Page.IsPostBack = True) Then
) A- F" ~1 M5 y' r' tsetScrollPosition.Append("<script language='javascript'>")
1 h' ?. d0 Z5 hsetScrollPosition.Append("function setScrollPosition() {")
4 K5 Y! ]/ @$ u9 M7 D C: J Q3 F. z2 hsetScrollPosition.Append(" document.body.scrollTop = " & Request("__SCROLLPOS") & ";")
4 ^) f2 C2 k/ a& W- d/ \2 z" P% osetScrollPosition.Append("}")- m+ t' _# p2 ^) d
setScrollPosition.Append("document.body.onload=setScrollPosition;")
" B% Z. Q2 e1 g6 L3 XsetScrollPosition.Append("</script>")3 p8 w& T5 H* ~% t. Z
RegisterStartupScript("setScroll", setScrollPosition.ToString())4 }; d9 ]0 L6 L8 r! ^- {9 b/ n
End If
& K* k4 N# o, z9 w" D3 OEnd Sub2 J: N9 x- E7 F5 z- }3 l9 n
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles
- h) W! ]' [9 \5 @ u+ X' z% q8 JMyBase.Load
3 W4 x2 N' Y* W$ H ]# B) \RetainScrollPosition()
2 z* l9 ^' j; A4 E7 qEnd Sub
7 b3 M0 \( K2 p* j' v' V/ k0 D9 m
$ U! X4 R+ q( z) A' F3. DataList使用不同风格的模板
3 I% v6 ?3 U4 `0 P- A 这招也非常实用,你可以制作两个不同的模板或表现形式,分别以.ascx控件的形式保存,运行时根据某个条$ j9 }# V# \$ |9 q
件动态的选择使用其中的一个模板,另外ScottGu认为ItemDataBound方法也可以定制你显示的表现,比如加亮某个
. [- j. `3 d ^1 W- g元素或是加一个促销广告图等等。7 a' e; T: @4 f2 K+ X; I
Dim theme As String
+ [4 S% i- p1 ?$ b$ f% K* s; O& ytheme = DropDownList1.SelectedValue
% R8 N" Y8 c) LDataList1.ItemTemplate = Page.LoadTemplate(theme & ".ascx") ---Cool- s( \( V% M: W% x
DataList1.DataSource = DS( N, Z5 D2 X7 G. J8 h
DataList1.DataBind() 9 g* U4 U9 U/ j6 S
4. 设置服务器端控件的焦点
8 |* D; `9 a! d. }$ [) s9 HPrivate Sub SetFocus(ByVal controlToFocus As Control) S" { w W. J
Dim scriptFunction As New StringBuilder
5 l T" f) l% r: \; O! HDim scriptClientId As String
1 m% M: a# k" W. a4 e. u/ |( H0 QscriptClientId = controlToFocus.ClientID: K+ M2 J' e& \% I4 ^3 J/ N
scriptFunction.Append("<script language='javascript'>")
/ O( P8 R7 `. H3 [& O4 b1 E6 UscriptFunction.Append("document.getElementById('" & scriptClientId & "').focus();")
. B3 |* N& Z KscriptFunction.Append("</script>")7 K1 ~7 V* `# J- d# J) K
RegisterStartupScript("focus", scriptFunction.ToString())- f2 F7 ^* `# g9 v3 X
End Sub
/ ]7 {9 \: [5 G( k, rPrivate Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles - r+ |6 n, V; d; G8 e
MyBase.Load( V% R8 U" A# n+ i. {; o' v" d
If (Page.IsPostBack = False) Then
* w% \$ r" `" |9 t% E) H, a! dSetFocus(TextBox1)
. H- o, [' o( @9 `0 S. P: WEnd If
( L/ |1 c+ ^* b! ^, QEnd Sub
) ~; \2 o6 C$ m1 u" M- }' F 5. 滚动DataGrid. Y- j6 G% k6 h8 D
这招就更简单了,有时候你的页面只有一个固定的地方,但是需要显示非常多的数据,亦或是也不定,但是只( o" j7 A2 A+ n2 j/ i1 k
有固定的一个地方给你显示它了。这时你就可以用下面这招,自动出滚动条,而且适用许多控件。很简单将你的控
6 f1 z! f0 y1 d' d: Q件放在一个DIV中将overflow属性设置成auto/ J0 b% U) w2 C- N6 I S
<div style=“height:400px;width:200px;overflow:auto”>$ m* \" p0 G. k# y4 d/ e) S
<asp:datagrid id=“MyGrid” runat=“server”/>
4 r( `& D* _' U0 ?% ^( M) d</div> . F9 v3 c6 h6 [0 j1 t; w* C/ t& v$ c
6. 动态创建控件; Y7 R2 d9 q0 A8 }! o8 T) p: }
利用PlaceHolder控件,这东西在ASP.NET 2.0 Mutil-View和Master Page中运用的就更加多了。) C1 k |. U" Z
Sub Page_Load()/ Y* l; k0 a, k$ d! }3 l% Y* p
Dim i as Integer$ u* y% s4 [1 X, Q
For i=0 to 4 8 J0 U3 w' O) k# a# ^
Dim myUserControl as Control
! u: \: D; M7 u% u1 x6 w1 zmyUserControl = Page.LoadControl(“foo.ascx”)
' u; U5 k t: [ v" sPlaceHolder1.Controls.Add(myUserControl): ?) V- k" D6 W" S6 ~! U
PlaceHolder1.Controls.Add(New LiteralControl(“<br>”))) m& {# r' S7 C
Next i
V1 l- }% @" q c/ R$ \( o7 qEnd Sub
) `. I0 t1 M# P 7. 客户端代码的使用8 H O6 p4 K* |* n4 d
1). 可以使用客户端的事件代码,但两者不能同名,服务器端代码的名是你可以控制的。对于非ASP.NET的标
: Z' q7 n8 @+ r0 C7 f' P6 \准控件的自定义控件必须实现IAttributeAccessor接口或从WebControl派生并且可用expando属性- r+ }* Z3 u" Z" {; V u
asp:ImageButton id=“foo” v8 p, Y! f6 K0 ] @& E
ImageUrl=“start.jpg”5 p# q! E9 x- b9 g% s0 S" M% @" v8 p1 k
onMouseOver=“rollover(this);” ! T/ R5 ^" x3 M! j, g2 u, o8 x
onMouseOut=“rollout(this)”
! y' N( @/ U1 v9 Rrolloversrc=“myrollover.jpg”; B4 i) L/ e3 m
rolloutsrc=“myrollout.jpg”
/ Z: O( G# J1 y& B. h6 Q3 p% N: vrunat=“server”/>9 G T5 T [/ c4 A: F
<input type=Button onClick=“return clientHandler()” ) T$ m; x9 |( Z" b
onServerClick=“Button1_Click” … /> 6 N& ]7 t9 u( T3 p( I9 {
2). 使用可以在Postback之前执行客户端代码,当然也可以取消这次Postback,另外也可以访问客户端该页所. O) I+ S9 Z! a/ f3 L1 ~& o* } q6 k
有的客户端控件。/ ]1 ^) M, r7 R
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles v$ c; n( s+ L* u6 e2 A8 Z
MyBase.Load
) \% H$ e% B! w+ E" | RegisterOnSubmitStatement("foo", "return confirm('Are you sure you want to submit the order?');")
7 F, b" T/ P! N( fEnd Sub " x4 a9 u5 [, e; s/ x7 M: w
3). 还有更复杂的我认为不实用,大家可以自己去看,主要是运用RegisterStartupScript和JavaScript的技术 |
|