IEditableCollectionView.CommitNew メソッド

定義

トランザクションの追加を終了し、保留中の新しい項目を保存します。

public:
 void CommitNew();
public void CommitNew();
abstract member CommitNew : unit -> unit
Public Sub CommitNew ()

次の使用例は、ユーザーに新しい項目の追加を求めるフォームを表示します。 ユーザーがフォームを送信した場合、この例では CommitNew を呼び出してアイテムをコレクションに追加します。 ユーザーがフォームを取り消した場合、この例では CancelNew を呼び出してアイテムを破棄します。 サンプル全体については、「 IEditableCollectionView サンプルを使用したコレクションの変更」を参照してください。

IEditableCollectionView editableCollectionView =
    itemsControl.Items;

if (!editableCollectionView.CanAddNew)
{
    _ = MessageBox.Show("You cannot add items to the list.");
    return;
}

// Create a window that prompts the user to enter a new
// item to sell.
ChangeItemWindow win = new()
{
    //Create a new item to be added to the collection.
    DataContext = editableCollectionView.AddNew()
};

// If the user submits the new item, commit the new
// object to the collection.  If the user cancels 
// adding the new item, discard the new item.
if ((bool)win.ShowDialog())
{
    editableCollectionView.CommitNew();
}
else
{
    editableCollectionView.CancelNew();
}
Dim editableCollectionView As IEditableCollectionView = TryCast(itemsControl.Items, IEditableCollectionView)

If Not editableCollectionView.CanAddNew Then
    MessageBox.Show("You cannot add items to the list.")
    Return
End If

' Create a window that prompts the user to enter a new
' item to sell.
Dim win As New ChangeItemWindow()

'Create a new item to be added to the collection.
win.DataContext = editableCollectionView.AddNew()

' If the user submits the new item, commit the new
' object to the collection.  If the user cancels 
' adding the new item, discard the new item.
If CBool(win.ShowDialog()) Then
    editableCollectionView.CommitNew()
Else
    editableCollectionView.CancelNew()
End If

注釈

CollectionViewに適用されるフィルター処理、並べ替え、またはグループ化は、CommitNewが呼び出されたときに新しい項目に適用されます。

適用対象