See Also: ICancelAddNew
The ICancelAddNew interface enables a collection to add a new item in an extensible way. The new item subsequently can be committed or rolled back. The IBindingList.AddNew method of the collection is used to tentatively add the item, which is subsequently transacted through the following operations:
The ICancelAddNew.EndNew(Int32) method will explicitly commit the pending addition.
Performing another collection operation, such as an insertion, removal, or move will implicitly commit the pending addition.
The ICancelAddNew.CancelNew(Int32) method will roll back the pending addition if it has not already been committed.
In some scenarios, such as Windows Forms complex data binding, the collection may receive ICancelAddNew.CancelNew(Int32) or ICancelAddNew.EndNew(Int32) calls for items other than the newly added item. (Each item is typically a row in a data view.) Ignore these calls; cancel or commit the new item only when that item's index is specified.
There are two models that allow transactional addition of an item to a data-bound collection:
The older model relies directly on a collection that implements the IBindingList interface and is data-bound directly using the CurrencyManager class. The CurrencyManager.AddNew, CurrencyManager.EndCurrentEdit, and CurrencyManager.CancelCurrentEdit methods of the CurrencyManager class are responsible for transactional support for adding new items. However, this functionality depends upon the items supporting transactional behavior through the IEditableObject interface. If the items do not support this interface, the item will always be added to the list, regardless of subsequent calls to CurrencyManager.CancelCurrentEdit.
The newer model supports a more robust data-binding scenario through the generic BindingList`1 class, which implements the IBindingList and ICancelAddNew interfaces. In this case, the transactional support is managed by the BindingList`1 collection directly.
Assembly: System (in System.dll)
Assembly Versions: 22.214.171.124, 126.96.36.199
The members of System.ComponentModel.ICancelAddNew are listed below.