TA的每日心情 | 衰 2019-8-18 09:37 |
|---|
签到天数: 2 天 [LV.1]初来乍到
|
随着微软.NET的流行,ASP.NET越来越为广大开发人员所接受。作为ASP.NET的开发人员,我们不仅需要掌握其基 本的原理,更要多多实践,从实践中获取真正的开发本领。在我们的实际开发中,往往基本的原理满足不了开发需
) M, ~; \, ^- p求,我们更多的要积累一些开发技巧,本文就向大家介绍一些实用技巧,希望对大家的开发有所裨益。
2 c% S/ Y+ O4 e3 ~ 1. ~ 的用法+ V1 g0 N1 w: s4 t
一般的情况下,我们是使用./../ 这样的相对路径来确定和规划我们的资源(比如图片、资源文件),但这种方
1 u4 O$ e" w- C0 h0 a) T5 Q- B式下在我们部署应用的时候,可能会出错,另外对于.ascx的控件中如果包含了一个图片,而这个控件被我们在不
- [/ t+ D( [% r2 _1 E3 v/ w8 g/ a4 z同层次的两个目录的aspx文件分别引用时,问题就会出现了。
$ \# z- \: v+ W ~/image/about.bmp
$ ?/ @3 W, N" ]0 _: z% x f是一种非常好的方法,它以Web应用程序的根目录为起始点,这样使得比你使用./image/about.bmp这样的方式要更
, j( k& [" x1 f) U加灵活和方便。有一点不好,是这种方式是在ASP.NET运行时动态解析的,所以在IDE设计模式中,你可能不能预览
$ N/ t/ ?8 h4 ^9 N" T5 e它。
" @% X* U1 a1 x$ @1 G 2. 在刷新和提交页面后,保存你的页面滚动条的位置
$ A& P8 E+ z4 u 经常有这样的情况,我们需要用户提交一个表单,但是表单中有超过500+个?控件或文本框要填写,也就是说 b4 k C! ~+ l& _6 m
用户需要拉动IE的滚动条才能够填得完,那么假如用户正在可见IE范围的2/3处,选择了一个组合框的值,很不幸3 L% A* o) G- F* k
组合框是服务器端的,那么也就意味着页面会提交一次,而当用户再看见刷新过的页面时,页面确定在3/1的地方
: k7 {7 K. y8 L7 o9 o也就是显示在页面最开始的地方,用户只有拖动鼠标,然后接着刚刚的地方再填写剩下的250个控件,很不幸,370
3 x. l e- [+ \+ v- u8 n个控件又需要他选择一下?
5 g5 L# x9 ~# F3 i5 h, \: \2 F# X0 _ 用下面的方法可以很快地确定和记住你提交前的位置。' r2 J$ W, e( r9 N
网上的Old Dog Learns New Tricks也有一个类似的例子Maintain Scroll Position in any Page Element,! x+ S2 l$ H, f7 j
不过他使用了Web Behavior这意味着你需要使用一个.htc文件. x- |% N$ r; Y P& s5 k1 v
Private Sub RetainScrollPosition() [2 ]# f: ~0 |1 w" ?
Dim saveScrollPosition As New StringBuilder9 b, u/ _$ t$ {
Dim setScrollPosition As New StringBuilder
5 W/ K- r0 m7 I& C& F4 kRegisterHiddenField("__SCROLLPOS", "0")2 p$ K8 f5 z! }3 r# Y
saveScrollPosition.Append("<script language='javascript'>")
; G6 Y/ Y$ u4 _saveScrollPosition.Append("function saveScrollPosition() {")* @+ w8 G0 v+ M7 T( ^3 t
saveScrollPosition.Append(" document.forms[0].__SCROLLPOS.value = document.body.scrollTop;")
2 o( m3 E }+ p. n$ s, esaveScrollPosition.Append("}")
$ t2 _8 P! @5 I3 i AsaveScrollPosition.Append("document.body.onscroll=saveScrollPosition;")
1 T, `+ T! _+ o1 q) W- l; o7 tsaveScrollPosition.Append("</script>")
/ O; m1 o; [0 P+ Z/ YRegisterStartupScript("saveScroll", saveScrollPosition.ToString()), o- E+ Q6 A* M
If (Page.IsPostBack = True) Then7 i8 N+ m/ c! Q" C$ T/ v' _! Q
setScrollPosition.Append("<script language='javascript'>")
" k6 G1 p: Q3 i3 ] a" R! lsetScrollPosition.Append("function setScrollPosition() {")
( l- X2 [; X% hsetScrollPosition.Append(" document.body.scrollTop = " & Request("__SCROLLPOS") & ";")7 ?, L# z) A( x+ ?) i8 t
setScrollPosition.Append("}")1 D8 | B+ Y/ E& W6 N9 l
setScrollPosition.Append("document.body.onload=setScrollPosition;"); a; N& p/ @* Y; x$ m& `8 X
setScrollPosition.Append("</script>")7 b- G) X. U6 _
RegisterStartupScript("setScroll", setScrollPosition.ToString())4 Y* q7 {+ x5 V9 e% h" x! w) F2 L
End If
% J% k; k# k- t i* XEnd Sub* G! u2 W) ]7 U) @& c
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles
0 r( V4 F* \( ^1 F3 G% Z( {MyBase.Load
2 x+ t* J. k* }- A; b. CRetainScrollPosition()) y, L) a( E, d* i! Y/ Z
End Sub 0 g% A" e. K% }2 s8 F" k
0 N7 Y! J" i% \( u; A5 |9 L3. DataList使用不同风格的模板
2 H L' Q( X$ ^4 y2 Z 这招也非常实用,你可以制作两个不同的模板或表现形式,分别以.ascx控件的形式保存,运行时根据某个条5 o- E; s* a. V
件动态的选择使用其中的一个模板,另外ScottGu认为ItemDataBound方法也可以定制你显示的表现,比如加亮某个+ X2 r8 b5 j' e' q2 d7 c
元素或是加一个促销广告图等等。+ L0 p" v. o: k& e" d! s
Dim theme As String
- K/ K# L/ R/ T$ I+ p! W5 w" Ctheme = DropDownList1.SelectedValue5 Y0 F3 t/ i. [. G! P: L5 {3 B
DataList1.ItemTemplate = Page.LoadTemplate(theme & ".ascx") ---Cool" \3 a' z2 Y1 |: y7 w' G9 q) W
DataList1.DataSource = DS
, I: T! P5 R$ `2 xDataList1.DataBind()
( q, Q& o8 H! j& v 4. 设置服务器端控件的焦点
7 g7 H0 `. [& V, Q1 J- e0 NPrivate Sub SetFocus(ByVal controlToFocus As Control)
* O; |, R" [# Q2 |" ^Dim scriptFunction As New StringBuilder
8 a0 C* c2 L( {) a3 d. m+ xDim scriptClientId As String* T! k) J6 }- f- w
scriptClientId = controlToFocus.ClientID
# T% C3 K* B$ E+ nscriptFunction.Append("<script language='javascript'>")
6 J& A' P3 C# v5 q5 o# DscriptFunction.Append("document.getElementById('" & scriptClientId & "').focus();")
# B. s& i2 u3 s5 ZscriptFunction.Append("</script>")9 N! }( s f, `1 [' v0 g
RegisterStartupScript("focus", scriptFunction.ToString())
% ^' B: F5 ~1 e& _5 |1 pEnd Sub
# D6 V; q/ ^- E- M9 p6 z; a0 MPrivate Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles
3 l/ A4 c8 O6 e( V4 k5 zMyBase.Load1 O' P3 z. H8 p; Z
If (Page.IsPostBack = False) Then
9 F' K4 N) _% HSetFocus(TextBox1)0 _. V8 `0 C! D
End If" ]( z) d0 V, |# a5 ]
End Sub
1 u0 k: ]; D4 D 5. 滚动DataGrid) c) w) T5 `) k/ a& I/ ]5 S2 p
这招就更简单了,有时候你的页面只有一个固定的地方,但是需要显示非常多的数据,亦或是也不定,但是只- `. d& s2 ^& g, \
有固定的一个地方给你显示它了。这时你就可以用下面这招,自动出滚动条,而且适用许多控件。很简单将你的控
5 ~! V. j; S( K# Z, Q" O件放在一个DIV中将overflow属性设置成auto4 p& K+ u. T3 e" W/ M, e/ D
<div style=“height:400px;width:200px;overflow:auto”>
`" g; p1 w( r! Z<asp:datagrid id=“MyGrid” runat=“server”/>8 o6 _8 k/ F' O' b* [1 ^
</div> 1 x, t$ F5 t: h6 j- d3 M
6. 动态创建控件
! G# d9 p3 g0 A3 S/ J) U4 `" v 利用PlaceHolder控件,这东西在ASP.NET 2.0 Mutil-View和Master Page中运用的就更加多了。
2 v; w; y* }# z% r0 t q, n& i; wSub Page_Load()
& w6 ~ D. N e) XDim i as Integer
0 T) X: s* p1 s# T, Y" T4 a$ x$ t/ YFor i=0 to 4 1 l- w% |/ }. l. C6 o
Dim myUserControl as Control
# n$ O+ I: R( BmyUserControl = Page.LoadControl(“foo.ascx”)
6 v6 {& x% d- P- `1 APlaceHolder1.Controls.Add(myUserControl)
! ]- Y+ D8 {: d. ]PlaceHolder1.Controls.Add(New LiteralControl(“<br>”))
; h+ P; G6 _% k3 v1 x: QNext i
$ S4 O6 P9 c2 ]5 _) Y2 FEnd Sub / R& @$ l2 {/ z! U
7. 客户端代码的使用
! _ e7 H: Z* } 1). 可以使用客户端的事件代码,但两者不能同名,服务器端代码的名是你可以控制的。对于非ASP.NET的标: L# r( x4 X+ x# Q J+ s: [
准控件的自定义控件必须实现IAttributeAccessor接口或从WebControl派生并且可用expando属性4 x& Z. ?1 X; I
asp:ImageButton id=“foo”
8 ~+ i% A8 U: O; _! h8 y) W! HImageUrl=“start.jpg”% g3 ?4 z. W: e& E
onMouseOver=“rollover(this);”
1 l7 N7 j" [! {4 o% D2 R+ ionMouseOut=“rollout(this)”
2 ]3 p/ c5 q9 }, arolloversrc=“myrollover.jpg”$ d, Y* r0 S( f4 f! d+ W) }
rolloutsrc=“myrollout.jpg”
& k( h+ a/ M: B- m/ d% L& Y- Erunat=“server”/>
$ c \4 X v8 x5 x K' _& J<input type=Button onClick=“return clientHandler()”
3 z0 s" ]6 [, q: t1 {9 c$ a" KonServerClick=“Button1_Click” … /> * G1 l7 Z; i8 n8 L% J
2). 使用可以在Postback之前执行客户端代码,当然也可以取消这次Postback,另外也可以访问客户端该页所 D& x0 N r& a5 I1 J* n
有的客户端控件。- I8 q& w- `* ~5 q
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 0 K/ \2 |5 q: n" \3 K% E
MyBase.Load6 D8 y g6 x* F: O: r4 d5 L* H
RegisterOnSubmitStatement("foo", "return confirm('Are you sure you want to submit the order?');")
l* |3 R( P# Y- N! gEnd Sub
0 a9 F- @5 _" M: y5 `, J, D 3). 还有更复杂的我认为不实用,大家可以自己去看,主要是运用RegisterStartupScript和JavaScript的技术 |
|