NewRowNeeded和UserAddedRow事件以及RowsAdded的区别使用

NewRowNeeded事件当 VirtualMode 属性为 true 时,将在用户定位到 DataGridView 底部的新行时发生,适合给新行建立一些默认数据和按规则应该产生的数据,但此时不推荐添加新数据到后台数据表中。因为用户操作有太多的变数,可以把产生的默认值直接赋值给一个临时初始数据对像即可,在用户触发UserAddedRow事件后,再赋值到后台数据也不迟

  1. Private pInitData As OuterExtendItem
  2. Private Sub xDataGridView_NewRowNeeded(sender As Object, e As System.Windows.Forms.DataGridViewRowEventArgs) Handles xDataGridView.NewRowNeeded
  3. If (mHalt) Then
  4. Return
  5. End If
  6. pInitData = New OuterExtendItem()
  7. pInitData.mTitle = ""
  8. pInitData.mValue = ""
  9. End Sub

官方说明:https://msdn.microsoft.com/zh-cn/library/system.windows.forms.datagridview.newrowneeded(VS.80).aspx

UserAddedRow事件是在编辑新行时触发,此时适合添加数据到后台数据表中

如例:

  1. Private Sub xDataGridView_UserAddedRow(sender As Object, e As System.Windows.Forms.DataGridViewRowEventArgs) Handles xDataGridView.UserAddedRow
  2. If (mHalt) Then
  3. Return
  4. End If
  5. If (_ExtendList Is Nothing) Then
  6. Return
  7. End If
  8. If (pInitData IsNot Nothing) Then
  9. _ExtendList.addNotEvent(pInitData)
  10. pInitData = Nothing
  11. End If
  12. End Sub

//参考的数据显示代码:

  1. Private Sub xDataGridView_CellValueNeeded(sender As Object, e As System.Windows.Forms.DataGridViewCellValueEventArgs) Handles xDataGridView.CellValueNeeded
  2. If (mHalt) Then
  3. Return
  4. End If
  5. If (e.RowIndex < 0 OrElse e.RowIndex > _ExtendList.Count) Then
  6. Return
  7. End If
  8. If (e.RowIndex = _ExtendList.Count AndAlso pInitData IsNot Nothing) Then
  9. ‘显示新行的代码
  10. Select Case e.ColumnIndex
  11. Case xColumnTitle.Index
  12. e.Value = pInitData.mTitle
  13. Case xColumnValue.Index
  14. e.Value = pInitData.mValue
  15. End Select
  16. Else
  17. With _ExtendList
  18. Select Case e.ColumnIndex
  19. Case xColumnTitle.Index
  20. e.Value = .Item(e.RowIndex).mTitle
  21. Case xColumnValue.Index
  22. e.Value = .Item(e.RowIndex).mValue
  23. End Select
  24. End With
  25. End If
  26. End Sub
  1. Private Sub xDataGridView_CellValuePushed(sender As Object, e As System.Windows.Forms.DataGridViewCellValueEventArgs) Handles xDataGridView.CellValuePushed
  2. If (mHalt) Then
  3. Return
  4. End If
  5. If (e.RowIndex < 0 OrElse e.RowIndex >= _ExtendList.Count) Then
  6. Return
  7. End If
  8. With _ExtendList(e.RowIndex)
  9. Try
  10. Select Case e.ColumnIndex
  11. Case xColumnTitle.Index
  12. .mTitle = e.Value
  13. Case xColumnValue.Index
  14. .mValue = e.Value
  15. End Select
  16. .raiseValueChangedEvent(_ExtendList, EventArgs.Empty) //触发列表变化事件
  17. Catch exp As Exception
  18. MyHub.mBase.mDebugLog.writerError(Me, exp)
  19. Finally
  20. End Try
  21. End With
  22. End Sub
  1.   ‘列表变化事件,此处只要根据实际数据,设置行数即可
  2. Private Sub listChanged(sender As Object, ByVal e As DBListChangedEventArgs(Of OuterExtendItem))
  3. If (Me.InvokeRequired) Then
  4. Me.BeginInvoke(New EventHandler(Of DBListChangedEventArgs(Of OuterExtendItem))(AddressOf listChanged), New Object() {sender, e})
  5. Else
  6. xDataGridView.RowCount = _ExtendList.Count + 1 //行数+1行
  7. xDataGridView.Refresh()
  8. End If
  9. End Sub

RowsAdded事件,此事件是指在表格增加新行时触发,在初始化数据增加新行和后期编辑增加新行时都会触发此事件,而UserAddedRow事件一般是指在编辑阶段由用户操作触发的增加新行事件,二者有所区别,UserAddedRow事件使用率会比较高一点,RowsAdded事件适用于产生一些根据绑定数据需要额外显示的信息时。

时间: 2024-08-10 21:14:33

NewRowNeeded和UserAddedRow事件以及RowsAdded的区别使用的相关文章

总结oninput、onchange与onpropertychange事件的用法和区别 书写搜索的神奇代码

总结oninput.onchange与onpropertychange事件的用法和区别 最近手机开发一个模糊搜索的功能组建,在网上就找到这篇文章! 前端页面开发的很多情况下都需要实时监听文本框输入,比如腾讯微博编写140字的微博时输入框hu9i动态显示还可以输入的字数.过去一般都使用onchange/onkeyup/onkeypress/onkeydown实现,但是这存在着一些不好的用户体验.比如onchange事件只在键盘或者鼠标操作改变对象属性,且失去焦点时触发,脚本触发无效:而onkeyd

C# 事件与委托的区别

C# 事件与委托的区别 先看一段程序 class Program { static void Main(string[] args) { Test obj = new Test(); obj.print += printout1; //绑定printout1方法 obj.print += printout2; //绑定printout2方法 obj.start(); } static void printout1() { Console.WriteLine("输出第一段字符串"); }

html5与js关于input[type=&#39;text&#39;]文本框value改变触发事件一些属性的区别oninput,onpropertychange,onchange和文本框的value点击全选状态onclick=&quot;select();&quot;。做购物车页面时会要用到。

关于input[type='text']文本框value改变触发事件一些属性的区别oninput,onpropertychange,onchange和文本框的点击全选状态onclick="select();".做购物车页面时会要用到. input[type='text']文本框value改变触发事件一些属性的区别oninput,onpropertychange,onchange: 1.onchange事件与onpropertychange事件的区别:onchange事件在内容改变(两次

总结oninput、onchange与onpropertychange事件的用法和区别

前端页面开发的很多情况下都需要实时监听文本框输入,比如腾讯微博编写140字的微博时输入框hu9i动态显示还可以输入的字数.过去一般都使用onchange/onkeyup/onkeypress/onkeydown实现,但是这存在着一些不好的用户体验.比如onchange事件只在键盘或者鼠标操作改变对象属性,且失去焦点时触发,脚本触发无效:而onkeydown/onkeypress/onkeyup在处理复制.粘贴.拖拽.长按键(按住键盘不放)等细节上并不完善. onpropertychange属性可

事件和方法的区别

事件:指的是一个类有可能会引发的一个调用,任何类都可以向一个有事件的类注册这个事件的监听,那么当事件引发时,类就会受到事件通知,从而响应. 方法:指的是一个类的一些操作,比如一个Car类他有一个Move的移动方法,表示这个车子可以移动的操作(Operation). 对于BOM对象可有方法和事件,其区别在于: 1.事件名前一般都以on开头. 2.方法是程序员写语句直接调用,即显示调用:事件不需程序员调用,但是,必须由程序员写一个函数且将该函数赋值给相应的事件,其调用是在相应的事件触发时.

DOM事件对象、IE事件对象、旧浏览器事件对象的JavaScript区别

事件流: 事件冒泡:即事件最开始由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播至最不具体的那个节点(文档). 事件捕获:不太具体的节点应该更早接收到事件,而最具体的节点最后接收到事件. DOM2级事件处理程序: .addEventListener();      .removeEventListener(); 在IE浏览器中不起作用!IE事件处理程序: .attachEvent();     .detachEvent(); 跨浏览器常用事件处理程序: var eventUt

Touch事件详解及区别,触屏滑动距离计算

移动端有四个关于触摸的事件,分别是touchstart.touchmove.touchend.touchcancel(比较少用), 它们的触发顺序是touchstart-->touchmove-->touchend-->click,所以touch事件触发完成后会接着触发click事件,需要注意一下 ,阻止一下事件冒泡就可以了. touch事件可以产生一个event对象,这个event对象除基本的一些属性外还附带了三个额外的属性: touches 一个TouchList对象,包含当前所有屏

JQuery中阻止事件冒泡方式及其区别

方式一:event.stopPropagation(); 1 $("#div1").mousedown(function(event){ 2 event.stopPropagation(); 3 }); 方式二:return false; 1 $("#div1").mousedown(function(event){ 2 return false; 3 }); 但是这两种方式是有区别的.return false 不仅阻止了事件往上冒泡,而且阻止了事件本身.event

【转】jQuery中的bind(),live(),delegate(),on()事件绑定方式的区别

bind()                                                                                                                                                                                                        简要描述 bind()向匹配元素添加一个或多个事件处理器. 使用方式 $(selecto