概要本文结合示例讲述了在ASP.net应用
程序中如何利用客户端的
Javascript脚本提高程序的执行效率并实现更多的功能。
一、ASP.Net与Javascript
.Net是微软公司下一代的战略核心,ASP.Net是.Net战略在Web开发方面的具体实现。它继承了ASP的简单性和易用性,同时克服了ASP程序结构化较差,难于阅读和理解的缺点。特别是服务器端控件和事件驱动模式的引入,使得Web应用程序的开发更接近于过去桌面程序的开发。
在各种各样介绍ASP.Net的文章和书籍中,都把重点放在了服务器控件和.NetFrameworkSDK上,因为这是ASP.Net中最新和最具革命性的改进;与此相反,在过去的Web开发中占据重要地位的客户端脚本Javascript(也包括
VBScript)则鲜有提及,似乎有了服务器端程序,已经不需要客户端脚本了。但是,服务器端的程序毕竟需要一次浏览器与Web服务器的交互,对于ASP.Net来说,就是一次页面的提交,需要来回传送大量的数据,而很多
工作,比如输入验证或者删除确认等,完全可以用Javascript来实现。因此,探讨在ASP.Net中如何使用Javascript仍然很有必要。
二、Javascript的应用示例
1.为页面上的某个服务器控件添加Javascript事件
服务器控件最终生成的仍然是普通的
HTML,比如
xml:namespace prefix = asp />
生成inputtext。表单中的每个HTML控件都有它自己的Javascript事件,比如Textbox有onchange事件,Button有onclick事件,Listbox有onchange事件等。要想为服务器控件添加客户端的事件,需要用到Attributes属性。Attributes属性是所有的服务器控件都有的一个属性,它用来为最终生成的HTML添加自定义的一些标记。假设WebForm上有一个保存按钮btnSave,希望在用户点此按钮时提示用户是否确实要保存(比如一旦保存就无法恢复等),则应在Page_Load事件中添加如下代码:
ifnotpage.isPostBack()then
btnSave.Attributes.Add(“onclick”,”Javascript:returnconfirm(‘Areyousuretosave?’);”)
endif
要注意的是‘return’,这是不可省的,否则即使用户点了取消,数据仍然会保存。
2.为Datagrid中的每一行添加Javascript事件
假设Datagrid的每一行有一个删除按钮,希望在用户点此按钮时提示用户是否确实要删除此条记录,以防用户点错了行,或仅仅是无意中点了删除按钮。
无论这个删除按钮是什么名字,都不能象上个例子那样直接引用,因为每一行都有这样一个按钮,它们是Datagrid中的子控件。在这种情况下,需要用到Datagrid的OnItemDataBound事件。OnItemDataBound事件发生在Datagrid的每一行数据绑定到Datagrid之后(即一行激发一次)。首先在Datagrid的声明中添加如下代码:
…Columnsdefinitionhere
此处说明OnItemDataBound事件发生时调用ItemDataBound方法,在代码后置文件中添加此方法的定义:
SubItemDataBound(ByValsenderAsObject,ByValeAsDataGridItemEventArgs)
Ife.Item.ItemType<>ListItemType.HeaderAnde.Item.ItemType<>ListItemType.FooterThen
DimoDeleteButtonAsLinkButton=e.Item.Cells(5).Controls(0)
oDeleteButton.Attributes("onclick")="javascript:returnConfirm('Areyousureyouwanttodelete"&;DataBinder.Eval(e.Item.DataItem,"m_sName")&;"?')"