TA的每日心情 | 衰 2019-8-18 09:37 |
---|
签到天数: 2 天 [LV.1]初来乍到
|
随着微软.NET的流行,ASP.NET越来越为广大开发人员所接受。作为ASP.NET的开发人员,我们不仅需要掌握其基 本的原理,更要多多实践,从实践中获取真正的开发本领。在我们的实际开发中,往往基本的原理满足不了开发需
3 e5 g4 `- k D' G求,我们更多的要积累一些开发技巧,本文就向大家介绍一些实用技巧,希望对大家的开发有所裨益。* u7 ?, S+ t* K8 @; m' R
1. ~ 的用法1 ^: @: ] t! g2 i: ^% b( ]% z
一般的情况下,我们是使用./../ 这样的相对路径来确定和规划我们的资源(比如图片、资源文件),但这种方* F m) V- V G4 J6 y
式下在我们部署应用的时候,可能会出错,另外对于.ascx的控件中如果包含了一个图片,而这个控件被我们在不# X" _3 _3 {$ V& A3 R% X
同层次的两个目录的aspx文件分别引用时,问题就会出现了。
0 m/ ?+ [/ [( f7 { ~/image/about.bmp
& x J" h4 U( w# ~! s4 @是一种非常好的方法,它以Web应用程序的根目录为起始点,这样使得比你使用./image/about.bmp这样的方式要更
' a$ d4 Z% _& e! A& d- k加灵活和方便。有一点不好,是这种方式是在ASP.NET运行时动态解析的,所以在IDE设计模式中,你可能不能预览) J) G& Z8 b! ?7 C! T
它。- z/ `, ]3 K" E$ R
2. 在刷新和提交页面后,保存你的页面滚动条的位置
+ a, d; `1 v3 c y( z 经常有这样的情况,我们需要用户提交一个表单,但是表单中有超过500+个?控件或文本框要填写,也就是说
5 g- W0 ]0 I. ~! V8 k& H, |用户需要拉动IE的滚动条才能够填得完,那么假如用户正在可见IE范围的2/3处,选择了一个组合框的值,很不幸
# C% p) ^+ E- Q; T组合框是服务器端的,那么也就意味着页面会提交一次,而当用户再看见刷新过的页面时,页面确定在3/1的地方/ ^; r% l7 U% `6 ]- l; W
也就是显示在页面最开始的地方,用户只有拖动鼠标,然后接着刚刚的地方再填写剩下的250个控件,很不幸,370% t* W# p5 D( L/ v) C
个控件又需要他选择一下?
' |7 Q, K. `# ^9 T 用下面的方法可以很快地确定和记住你提交前的位置。/ e9 `" S! y, f \& B6 ~
网上的Old Dog Learns New Tricks也有一个类似的例子Maintain Scroll Position in any Page Element,2 {- C! `! S* Y: Z- [$ X$ {
不过他使用了Web Behavior这意味着你需要使用一个.htc文件
# Y8 s0 i" @; c* a, [) Y( T+ ^3 n4 KPrivate Sub RetainScrollPosition() M/ w4 L' V# R& P* c
Dim saveScrollPosition As New StringBuilder
3 U3 l9 F) N% ^: hDim setScrollPosition As New StringBuilder
" j- y" g0 @2 E% aRegisterHiddenField("__SCROLLPOS", "0")
) ]$ N( S$ c9 o- a, UsaveScrollPosition.Append("<script language='javascript'>")
7 }# |1 e% V; q% O) D2 JsaveScrollPosition.Append("function saveScrollPosition() {")# X5 B+ \3 m; z2 O- S% m
saveScrollPosition.Append(" document.forms[0].__SCROLLPOS.value = document.body.scrollTop;")2 Y" @0 V( Y' v# X9 T$ v" W8 B5 T
saveScrollPosition.Append("}")
1 j5 y3 k3 Z9 w" I! LsaveScrollPosition.Append("document.body.onscroll=saveScrollPosition;"): x" V+ [( t' B" E& A- v& N( z
saveScrollPosition.Append("</script>")) M# g& @ Z, s7 l# p, V, Q7 z. H* r
RegisterStartupScript("saveScroll", saveScrollPosition.ToString()); k5 M2 w6 h: b7 Y$ U9 E) F8 I
If (Page.IsPostBack = True) Then
3 B$ x- C3 Q& P. H; Z; P# _* {& DsetScrollPosition.Append("<script language='javascript'>")- D6 p4 G+ L3 S Y0 E% C7 i
setScrollPosition.Append("function setScrollPosition() {"): S+ t/ r4 F2 p+ P) m% M
setScrollPosition.Append(" document.body.scrollTop = " & Request("__SCROLLPOS") & ";")0 ^+ S! _* E. @
setScrollPosition.Append("}")
+ |* N- x" k' W1 C4 a8 psetScrollPosition.Append("document.body.onload=setScrollPosition;")+ q% w/ K/ r. Y# D
setScrollPosition.Append("</script>")6 I( P6 {: j5 C' L; n
RegisterStartupScript("setScroll", setScrollPosition.ToString())
# h9 D9 [( {$ `) z0 [) bEnd If
6 x8 ?3 l' M4 B: s5 DEnd Sub- f, {0 J7 r% m% q
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ) `3 q4 g6 x; A9 B6 ]. x- f, x
MyBase.Load
% b% J! {2 ^4 {- o4 I" NRetainScrollPosition()
$ g9 G7 ?, @ TEnd Sub
0 Z/ i) T6 e4 j6 a! b% S* r+ p+ r' n d0 W# Y" ~! }
3. DataList使用不同风格的模板
) ~) } g m2 M. L6 j# E2 g 这招也非常实用,你可以制作两个不同的模板或表现形式,分别以.ascx控件的形式保存,运行时根据某个条' m# W. h- l# J& V
件动态的选择使用其中的一个模板,另外ScottGu认为ItemDataBound方法也可以定制你显示的表现,比如加亮某个
8 y6 A5 |2 ~9 |* D元素或是加一个促销广告图等等。
4 I# H f, K6 J! M+ IDim theme As String. G! D0 {- F" v1 v
theme = DropDownList1.SelectedValue
. c: H6 V$ P; g mDataList1.ItemTemplate = Page.LoadTemplate(theme & ".ascx") ---Cool
# K8 G0 R& W% R; m* V! }DataList1.DataSource = DS
9 X2 ^' K* h6 K+ Q* n3 mDataList1.DataBind()
. C2 _, a# i9 F* x4 M, ` 4. 设置服务器端控件的焦点
6 i1 ?7 _- e2 L% V7 ]+ O ~Private Sub SetFocus(ByVal controlToFocus As Control)4 `# r' G+ d7 Z; t
Dim scriptFunction As New StringBuilder
+ h9 @+ i4 a. ^: W2 [Dim scriptClientId As String
7 \$ v# l) G) [# ]: bscriptClientId = controlToFocus.ClientID
& B3 o' t5 z4 E+ S. z( D" zscriptFunction.Append("<script language='javascript'>")8 _+ H' a+ a3 {# L
scriptFunction.Append("document.getElementById('" & scriptClientId & "').focus();")
7 t) |2 g$ R* x: u/ G8 \scriptFunction.Append("</script>")* O" W x' n. S) o* V7 _! C
RegisterStartupScript("focus", scriptFunction.ToString())2 U; x, m" ?- g3 [
End Sub7 o4 @( q+ p( q0 r Q M
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles
5 R- W8 n) l8 t# I5 [MyBase.Load
% m- Y5 W- Z9 _: z" \3 L! ?3 K% VIf (Page.IsPostBack = False) Then- v7 i" D: u! M( o; I
SetFocus(TextBox1)) \9 ^1 ]& z1 q$ W3 N- c
End If
0 N" f5 ^. ]0 mEnd Sub 6 i1 C; H, m/ ?( E
5. 滚动DataGrid
- t& c E! W& c( W 这招就更简单了,有时候你的页面只有一个固定的地方,但是需要显示非常多的数据,亦或是也不定,但是只4 `2 {7 B( k) ~
有固定的一个地方给你显示它了。这时你就可以用下面这招,自动出滚动条,而且适用许多控件。很简单将你的控
9 L. X \. ]: b1 L: v7 A件放在一个DIV中将overflow属性设置成auto
) k; H' W# |/ T<div style=“height:400px;width:200px;overflow:auto”>
, k1 L# R2 I8 S3 l, r+ x<asp:datagrid id=“MyGrid” runat=“server”/>5 W* u; K& `+ l
</div>
5 ~) I! E( [6 d/ X 6. 动态创建控件 @1 q( V1 E4 @: ~
利用PlaceHolder控件,这东西在ASP.NET 2.0 Mutil-View和Master Page中运用的就更加多了。
+ L6 k, R0 \$ |7 [Sub Page_Load()
- p# x" c; B' [/ FDim i as Integer9 T" t J# ~9 ]3 h% D0 V
For i=0 to 4
1 u' t$ J7 W1 |+ |( n6 U/ ~6 j: `Dim myUserControl as Control% \$ Z; e) h* }: D" L- c# J' b
myUserControl = Page.LoadControl(“foo.ascx”)( h' X, @: I) O' c" q3 r& ^7 x
PlaceHolder1.Controls.Add(myUserControl)6 ~, m* ?* e: c$ ^$ k" G
PlaceHolder1.Controls.Add(New LiteralControl(“<br>”))& z1 j* w; p: [9 b
Next i+ i% A5 l- W7 m3 \ q
End Sub * a6 r! b" c; B |6 N3 f4 V$ x$ m
7. 客户端代码的使用
?" q2 o) {( F& g' A3 F 1). 可以使用客户端的事件代码,但两者不能同名,服务器端代码的名是你可以控制的。对于非ASP.NET的标
. S, P; x7 `5 p' ?' \准控件的自定义控件必须实现IAttributeAccessor接口或从WebControl派生并且可用expando属性
k6 l5 b( x) N# C+ d2 Pasp:ImageButton id=“foo”
! d6 J9 l' R3 c& [: I* OImageUrl=“start.jpg”: \9 Q) r: U! N9 x7 _4 H9 z, s
onMouseOver=“rollover(this);”
. S6 {5 u& p6 \9 J0 c5 ~: bonMouseOut=“rollout(this)”
7 P4 l8 k. ^" t. P! W$ c1 Hrolloversrc=“myrollover.jpg”5 O5 [) a5 k; U3 }- H& _: B
rolloutsrc=“myrollout.jpg”
c" f8 D9 F# _; D4 yrunat=“server”/>
( f6 U# ?1 ^+ Z+ b! I/ u! U: W<input type=Button onClick=“return clientHandler()” + e7 t+ z) d1 {0 W! U! ~- y
onServerClick=“Button1_Click” … />
% I; S: u) ?1 z- m 2). 使用可以在Postback之前执行客户端代码,当然也可以取消这次Postback,另外也可以访问客户端该页所 n8 [: u; n1 F- j) D
有的客户端控件。& e: d7 c" e! f1 {7 m* ^
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 8 K" i z6 x5 w! I( |6 @ R
MyBase.Load5 H% ~, Z; u: o8 m; d
RegisterOnSubmitStatement("foo", "return confirm('Are you sure you want to submit the order?');")
( G- ?/ m8 `1 t3 I4 uEnd Sub 0 [- j4 j$ G. P% I* b
3). 还有更复杂的我认为不实用,大家可以自己去看,主要是运用RegisterStartupScript和JavaScript的技术 |
|