观自在书院

海纳百川有容则大 壁立千仞无欲则刚

博客园 首页 新随笔 联系 订阅 管理

当你在开发ASP.NET Web应用程序时,会遇到这样的情况:你需要给一个ASPX页面呈现的HTML添加客户端脚本代码。有两种不同的方法可以让你在运行时添加这个代码。

第一种方法就是运用Page控件的RegisterClientScriptBlock方法,它可以让你在运行时给一个ASPX页面添加代码。该方法有两个参数——key和script。参数key是唯一的,可以识别你添加到页面的每个script块。你可以用IsClientScriptBlockRegistered属性以及key的值来避免重复添加脚本代码。参数script是个字符串,它包含你的客户端脚本代码。在用户点击了一个按钮时,下面的JavaScript代码会提示他们做确认:

Private Sub Page_Load(byval sender as Object, _
   ByVal e as EventArgs)

   ' Create your script code
   Dim sScript as String = "<script" & _ 
      "language=JavaScript> " 
   sScript = "function confirmDelete() {" 
   sScript += "confirm('Are you sure?');}"
   sScript += "</script>"

   If(Not _
      IsClientScriptBlockRegistered("MyScript") _
         ) Then
         RegisterClientScriptBlock("MyScript", _
            sScript)
   End If

End Sub

在将前面的脚本代码添加到你的Web页面后,你就需要一种方式从单独的控件来调用它。然而,你不能在设计时将一个客户端事件处理程序添加到按钮的onClick事件来调用你的confirmDelete函数。你需要一种方法在运行时添加客户端事件过程。当用户点击了按钮时,ASP.NET按钮控件会提交一个Web页面,触发服务器端的Button_Click()事件过程(event procedure)。

第二种在运行时添加客户端代码的方法就是运用Attributes属性,这是一个与服务器控件相关的属性集。在运行时,页面将你添加到该集合的任何属性呈现为HTML。从System.Web.UI.WebControls.WebControl派生的ASP.NET服务器控件,包括按钮和文本框,具有它们自己的Attributes集合属性。你可以用你的按钮的Attributes集合来调用confirmDelete函数:

btnDelete.Attributes.Add("onClick", _
   "return confirmDelete();")

上面的代码很可能出现在页面的OnLoad事件过程中。现在,当一个用户点击你的按钮时,一个确认信息框就会问他/她是否要进行删除操作。如果用户点击OK,该页面就被提交到服务器,并执行btnDelete_Click()事件过程中的任何代码。点击Cancel会阻止将页面提交到Web服务器。

当你有一个DataGrid控件,而且DataGrid允许用户删除网格(grid)中的一行时,你不需要某些客户端代码,你只需要点击网格上的Delete按钮就可以删除行了,但是删除时不会提示用户进行确认。这时Attributes属性就派得上用场了。你可以用DataGrid的ItemDataBound()服务器事件给网格中的每个删除按钮添加一个属性。当你用DataGrid的DataBind方法将数据绑定到网格时,所添加的每一行都会触发ItemDataBound事件。在事件中添加的代码如下:

Private Sub MyDataGrid_ItemDataBound(ByVal _
   Sender as object, ByVal e As _
   System.Web.UI.WebControls. _
   DataGridItemEventArgs) _
   Handles MyDataGrid.ItemDataBound

' This code adds javascript to the "Del" 
' button on each row in 
   ' the datagrid the javascript displays a 
   ' message box to the 
   ' user, confirming the delete action
   Dim btnDel As LinkButton
   Const DEL_COLUMN As Int16 = 1
      
   If Not (e.Item.ItemType = _
      ListItemType.Header Or _
   e.Item.ItemType = _
      ListItemType.Footer) Then

   btnDel = _
         e.Item.Cells(DEL_COLUMN).Controls(0)
   btnDel.Attributes.Add("onClick", _
         "confirmDelete();")

   End If

End Sub

在给你的ASP.NET应用程序添加客户端脚本代码后,你会很快地看到脚本代码所带来的好处。你的应用程序的用户将很感激你给他们提供了更具交互性、响应更快的界面。


关于作者:
Paul Delcogliano是Progressive Systems Consulting公司的技术主管,自Visual Studio .NET beta 1版本发布以来,他就一直在用它开发Windows和基于Web的应用程序了。你可以通过pdelco@progsys.com联系他。
posted on 2004-03-22 21:53  观自在书院  阅读(987)  评论(0编辑  收藏  举报