2006-11-25

ASP.NET 2.0高级数据处理之处理控件事件

来源: 天极 作者:佚名 评论 0 条
  在前面的部分中,你已经看到了几个数据控件事件的例子。数据控件的事件都是在页面执行生命周期的适当时候提供给你,供你插入自定义代码的。一般情况下,在某种特定的操作发生之前和之后,数据控件都会暴露事件。在某种操作之前调用的事件的名称一般带有-ing后缀,而在某种操作之后调用的事件的名称一般带有-ed后缀。例如,GridView所支持的事件包括:

  · PageIndexChanging和PageIndexChanged - 在分页操作之前和之后引发

  · SelectedIndexChanging和SelectedIndexChanged - 在选择操作发生之前和之后引发

  · Sorting和Sorted - 在排序操作之前和之后引发

  · RowEditing和RowCancelingEdit - 在数据行进入编辑模式之前或编辑模式被终止之前引发

  · RowUpdating和RowUpdated - 在更新操作之前和之后引发

  · RowDeleting和RowDeleted - 在删除操作之前和之后引发

  · RowDataBound - 当数据行进行数据绑定的时候引发

  · RowCreated - 当建立了数据行并显示的时候引发

  · RowCommand - 调用内部控件的按钮命令的时候引发

  数据源控件也暴露了一些事件,与数据绑定控件的事件类似。SqlDataSource和ObjectDataSource控件都支持下面一些事件:

  · Selecting和Selected - 在选择操作之前和之后引发

  · Updating和Updated - 在更新操作之前和之后引发

  · Deleting和Deleted - 在删除操作之前和之后引发

  · Inserting和Inserted - 在插入操作之前和之后引发

  · Filtering - 在过滤器操作发生之前引发

  当ObjectDataSource控件的TypeName属性所指定的对象建立或销毁的时候,它还提供了额外的事件。你可以通过设置随事件参数传递的ObjectInstance属性,在ObjectCreating事件中设置自定义的对象。

  · ObjectCreating和ObjectCreated - 在对象被建立之前和之后引发

  · ObjectDisposing - 在对象销毁之前引发

  某种操作之后引发的事件用于编写自定义代码来响应特定的操作,或检查操作的成功/失败状态。例如,你可以检查Update、Insert或Delete操作的RowsAffected,或检查Exception属性以确定在处理过程中是否发生了异常。你还可以设置事件参数的ExceptionHandled属性以防止异常显示在控件或页面上。下面的例子演示了GridView和SqlDataSource的多个事件处理代码,以及引发这些事件的相关次序。


(本文仅表明作者个人观点,不代表本站及其管理员立场.) 推荐 收藏 投稿 打印 返回 关闭
上一篇:ASP 动态包含文件的改进  
下一篇:使用xml http为网站增加域名查询功能
    评论加载中…
<script runat="server">

Protected Sub GridView1_RowEditing(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewEditEventArgs)
 ' 用户在只读模式中点击"编辑"按钮的时候引发
 Response.Write("Row editing...")

 ' 假如GridView已经处于编辑模式,就终止编辑操作
 If Not GridView1.EditIndex = -1 Then
  e.Cancel = True
 End If
End Sub

Protected Sub GridView1_RowUpdating(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewUpdateEventArgs)
' 当用户在编辑模式中点击"更新"按钮的时候引发
 Response.Write("GridView: Row updating...<br/>")
 
 '此处可以选择终止事件,例如不答应用户更新数据
 If User.IsInRole("Restricted") Then
  e.Cancel = True
 End If
End Sub
共2页: 上一页 1 [2] 下一页
 推荐文章
     

网站首页  -  网站地图 -   站长论坛  -  网站投稿  -    -  网站管理
Copyright © 2008 芜湖站长站 All Rights Reserved 皖ICP备07500611号