Export (0) Print
Expand All

BindingSource.AllowNew Property

Gets or sets a value indicating whether the AddNew method can be used to add items to the list.

Namespace:  System.Windows.Forms
Assembly:  System.Windows.Forms (in System.Windows.Forms.dll)

'Declaration
Public Overridable Property AllowNew As Boolean

Property Value

Type: System.Boolean
true if AddNew can be used to add items to the list; otherwise, false.

Implements

IBindingList.AllowNew

ExceptionCondition
InvalidOperationException

This property is set to true when the underlying list represented by the List property has a fixed size or is read-only.

MissingMethodException

The property is set to true and the AddingNew event is not handled when the underlying list type does not have a default constructor.

The default value for the AllowNew property depends on the underlying data source type. If the underlying list implements the IBindingList interface, this property will delegate to the underlying list. Otherwise, this property will return false if the underlying list has any of the following characteristics:

  • It has a fixed size, as determined by the IList.IsFixedSize property.

  • It is read-only, as determined by the IList.IsReadOnly property.

  • The item's type does not have a default constructor.

NoteNote

Once the value of this property is set, the getter no longer refers the call to the underlying list. Instead, it simply returns the value that was previously set until the ResetAllowNew method is called.

Setting this property raises the ListChanged event with ListChangedEventArgs.ListChangedType set to ListChangedType.Reset.

If you set the AllowNew property to true and the underlying list type does not have a default constructor, you must handle the AddingNew event and create the appropriate type.

The following code example demonstrates using the AllowNew property of the BindingSource component to permit the user to add new items to the BindingSource component's underlying list. Setting this property to true causes the bound DataGridView control to display its row for new records.

Public Sub New() 
    ' Set up the form. 
    Me.Size = New Size(800, 800)
    AddHandler Me.Load, AddressOf Form1_Load

    ' Set up the DataGridView control. 
    Me.customersDataGridView.AllowUserToAddRows = True 
    Me.customersDataGridView.Dock = DockStyle.Fill
    Me.Controls.Add(customersDataGridView)

    ' Add the StatusBar control to the form. 
    Me.Controls.Add(status)

    ' Allow the user to add new items. 
    Me.customersBindingSource.AllowNew = True 

    ' Attach the BindingSource to the DataGridView. 
    Me.customersDataGridView.DataSource = Me.customersBindingSource

End Sub

.NET Framework

Supported in: 4.5.2, 4.5.1, 4.5, 4, 3.5, 3.0, 2.0

.NET Framework Client Profile

Supported in: 4, 3.5 SP1

Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008 (Server Core Role not supported), Windows Server 2008 R2 (Server Core Role supported with SP1 or later; Itanium not supported)

The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.

Show:
© 2014 Microsoft