ASP.NET应用程序开发

七招制胜ASP.NET应用程序开发

<script language="javascript" src="http://www.51cto.com/php/ajax_art_2.js" type="text/javascript"></script>

 

1. ~ 的用法

一般的情况下,我们是使用./../ 这样的相对路径来确定和规划我们的资源(比如图片、资源文件),但这种方式下在我们部署应用的时候,可能会出错,另外对于.ascx的控件中如果包含了一个图片,而这个控件被我们在不同层次的两个目录的aspx文件分别引用时,问题就会出现了。

~/image/about.bmp

是一种非常好的方法,它以Web应用程序的根目录为起始点,这样使得比你使用./image/about.bmp这样的方式要更加灵活和方便。有一点不好,是这种方式是在ASP.NET运行时动态解析的,所以在IDE设计模式中,你可能不能预览它。

2. 在刷新和提交页面后,保存你的页面滚动条的位置

经常有这样的情况,我们需要用户提交一个表单,但是表单中有超过500+个?控件或文本框要填写,也就是说用户需要拉动IE的滚动条才能够填得完,那么假如用户正在可见IE范围的2/3处,选择了一个组合框的值,很不幸组合框是服务器端的,那么也就意味着页面会提交一次,而当用户再看见刷新过的页面时,页面确定在3/1的地方也就是显示在页面最开始的地方,用户只有拖动鼠标,然后接着刚刚的地方再填写剩下的250个控件,很不幸,370个控件又需要他选择一下?

用下面的方法可以很快地确定和记住你提交前的位置。

网上的Old Dog Learns New Tricks也有一个类似的例子Maintain Scroll Position in any Page Element,不过他使用了Web Behavior这意味着你需要使用一个.htc文件。

Private Sub RetainScrollPosition()

Dim saveScrollPosition As New StringBuilder

Dim setScrollPosition As New StringBuilder

RegisterHiddenField("__SCROLLPOS", "0")

saveScrollPosition.Append("<script language='javascript'>")

saveScrollPosition.Append("function saveScrollPosition() {")

saveScrollPosition.Append(" document.forms[0].__SCROLLPOS.value =

document.body.scrollTop;")

saveScrollPosition.Append("}")

saveScrollPosition.Append("document.body.οnscrοll=saveScrollPosition;")

saveScrollPosition.Append("</script>")

RegisterStartupScript("saveScroll", saveScrollPosition.ToString())

If (Page.IsPostBack = True) Then

setScrollPosition.Append("<script language='javascript'>")

setScrollPosition.Append("function setScrollPosition() {")

setScrollPosition.Append(" document.body.scrollTop = " & Request("__SCROLLPOS") & ";")

setScrollPosition.Append("}")

setScrollPosition.Append("document.body.οnlοad=setScrollPosition;")

setScrollPosition.Append("</script>")

RegisterStartupScript("setScroll", setScrollPosition.ToString())

End If

End Sub

Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles

MyBase.Load

RetainScrollPosition()

End Sub

3. DataList使用不同风格的模板

这招也非常实用,你可以制作两个不同的模板或表现形式,分别以.ascx控件的形式保存,运行时根据某个条件动态的选择使用其中的一个模板,另外ScottGu认为ItemDataBound方法也可以定制你显示的表现,比如加亮某个元素或是加一个促销广告图等等。

Dim theme As String

theme = DropDownList1.SelectedValue

DataList1.ItemTemplate = Page.LoadTemplate(theme & ".ascx") ---Cool

DataList1.DataSource = DS

DataList1.DataBind()

4. 设置服务器端控件的焦点

Private Sub SetFocus(ByVal controlToFocus As Control)

Dim scriptFunction As New StringBuilder

Dim scriptClientId As String

scriptClientId = controlToFocus.ClientID

scriptFunction.Append("<script language='javascript'>")

scriptFunction.Append("document.getElementById('" & scriptClientId & "').focus();")

scriptFunction.Append("</script>")

RegisterStartupScript("focus", scriptFunction.ToString())

End Sub

Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles

MyBase.Load

If (Page.IsPostBack = False) Then

SetFocus(TextBox1)

End If

End Sub

5. 滚动DataGrid

这招就更简单了,有时候你的页面只有一个固定的地方,但是需要显示非常多的数据,亦或是也不定,但是只有固定的一个地方给你显示它了。这时你就可以用下面这招,自动出滚动条,而且适用许多控件。很简单将你的控件放在一个DIV中将overflow属性设置成auto。

<div style=“height:400px;width:200px;overflow:auto”>

<asp:datagrid id=“MyGrid” runat=“server”/>

</div>

6. 动态创建控件

利用PlaceHolder控件,这东西在ASP.NET 2.0 Mutil-View和Master Page中运用的就更加多了。

Sub Page_Load()

Dim i as Integer

For i=0 to 4

Dim myUserControl as Control

myUserControl = Page.LoadControl(“foo.ascx”)

PlaceHolder1.Controls.Add(myUserControl)

PlaceHolder1.Controls.Add(New LiteralControl(“<br>”))

Next i

End Sub

7. 客户端代码的使用

1). 可以使用客户端的事件代码,但两者不能同名,服务器端代码的名是你可以控制的。对于非ASP.NET的标准控件的自定义控件必须实现IAttributeAccessor接口或从WebControl派生并且可用expando属性。

asp:ImageButton id=“foo”

ImageUrl=“start.jpg”

onMouseOver=“rollover(this);”

onMouseOut=“rollout(this)”

rolloversrc=“myrollover.jpg”

rolloutsrc=“myrollout.jpg”

runat=“server”/>

<input type=Button onClick=“return clientHandler()”

onServerClick=“Button1_Click” … />

2). 使用可以在Postback之前执行客户端代码,当然也可以取消这次Postback,另外也可以访问客户端该页所有的客户端控件。

Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs)  

Handles

MyBase.Load

 RegisterOnSubmitStatement("foo",

"return confirm('Are you sure you want to submit the order?');")

End Sub

3). 还有更复杂的我认为不实用,大家可以自己去看,主要是运用RegisterStartupScript和JavaScript的技术。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值