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

七招制胜asp.net应用程序开发
随着微软.net的流行,asp.net越来越为广大开发人员所接受。作为asp.net的开发人员,我们不仅需要掌握其基本的原理,更要多多实践,从实践中获取真正的开发本领。在我们的实际开发中,往往基本的原理满足不了开发需求,我们更多的要积累一些开发技巧,本文就向大家介绍一些实用技巧,希望对大家的开发有所裨益。

 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 retainscrollpositi

dim savescrollposition as new stringbuilder
dim setscrollposition as new stringbuilder

registerhiddenfield("__scrollpos", "0")
savescrollposition.append("<script language='javascript'>")
savescrollposition.append("function savescrollpositi {")
savescrollposition.append(" document.forms[0].__scrollpos.value = thebody.scrolltop;")
savescrollposition.append("}")
savescrollposition.append("thebody.
savescrollposition.append("</script>")

registerstartupscript("savescroll", savescrollposition.tostring())

if (page.ispostback = true) then

setscrollposition.append("<script language='javascript'>")
setscrollposition.append("function setscrollpositi {")
setscrollposition.append(" thebody.scrolltop = " & request("__scrollpos") & ";")
setscrollposition.append("}")
setscrollposition.append("thebody.
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
retainscrollpositi
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 c as c
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 myuserc as c
myuserc = page.loadcontrol(“foo.ascx”)
placeholder1.controls.add(myuserc
placeholder1.controls.add(new literalc
next i
end sub


  7. 客户端代码的使用

  1). 可以使用客户端的事件代码,但两者不能同名,服务器端代码的名是你可以控制的。对于非asp.net的标准控件的自定义控件必须实现iattributeaccessor接口或从webc

asp:imagebutton id=“foo”
imageurl=“start.jpg”


rolloversrc=“myrollover.jpg”
rolloutsrc=“myrollout.jpg”
runat=“server”/>

<input type=button clienthandler()”
… />


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

private sub page_load(byval sender as system.object, byval e as system.eventargs)  handles mybase.load
 registeronsubmitstatement("foo", "return c you sure you want to submit the order?');")
end sub


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

  以上文章介绍了一些asp.net中常用而且比较实用的技巧,希望能对大家的实际开发有所裨益!
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值