Suggérer une traduction
 
Suggestions d'autres utilisateurs :

progress indicator
Aucune autre suggestion.
Cliquez pour évaluer et commenter
MSDN
MSDN Library
Développement .NET
.NET Framework 4
Espaces de noms System.Web
System.Web.UI.WebControls
ListView, classe
Réduire tout/Développer tout Réduire tout
Affichage du contenu :  côte à côteAffichage du contenu : côte à côte
.NET Framework Class Library
ListView Class

Displays the values of a data source by using user-defined templates. The ListView control enables users to select, sort, delete, edit, and insert records.

Namespace:  System.Web.UI.WebControls
Assembly:  System.Web.Extensions (in System.Web.Extensions.dll)
Visual Basic
<ControlValuePropertyAttribute("SelectedValue")> _
<ToolboxBitmapAttribute(GetType(ListView), "ListView.bmp")> _
Public Class ListView _
    Inherits DataBoundControl _
    Implements INamingContainer, IPageableItemContainer, IPersistedSelector, IDataKeysControl,  _
    IDataBoundListControl, IDataBoundControl
C#
[ControlValuePropertyAttribute("SelectedValue")]
[ToolboxBitmapAttribute(typeof(ListView), "ListView.bmp")]
public class ListView : DataBoundControl, INamingContainer, 
    IPageableItemContainer, IPersistedSelector, IDataKeysControl, IDataBoundListControl, IDataBoundControl
Visual C++
[ControlValuePropertyAttribute(L"SelectedValue")]
[ToolboxBitmapAttribute(typeof(ListView), L"ListView.bmp")]
public ref class ListView : public DataBoundControl, 
    INamingContainer, IPageableItemContainer, IPersistedSelector, IDataKeysControl, IDataBoundListControl, 
    IDataBoundControl
F#
[<ControlValuePropertyAttribute("SelectedValue")>]
[<ToolboxBitmapAttribute(typeof(ListView), "ListView.bmp")>]
type ListView =  
    class
        inherit DataBoundControl
        interface INamingContainer
        interface IPageableItemContainer
        interface IPersistedSelector
        interface IDataKeysControl
        interface IDataBoundListControl
        interface IDataBoundControl
    end
ASP.NET
<asp:ListView />

The ListView type exposes the following members.

  NameDescription
Public methodListViewInitializes a new instance of the ListView class.
Top
  NameDescription
Public propertyAccessKeyOverrides the WebControl..::.AccessKey property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.AccessKey.)
Protected propertyAdapterGets the browser-specific adapter for the control. (Inherited from Control.)
Public propertyAlternatingItemTemplateGets or sets the custom content for the alternating data item in a ListView control.
Public propertyAppRelativeTemplateSourceDirectoryGets or sets the application-relative virtual directory of the Page or UserControl object that contains this control. (Inherited from Control.)
Public propertyAttributesGets the collection of arbitrary attributes (for rendering only) that do not correspond to properties on the control. (Inherited from WebControl.)
Public propertyBackColorOverrides the WebControl..::.BackColor property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.BackColor.)
Public propertyBindingContainerInfrastructure. Gets the control that contains this control's data binding. (Inherited from Control.)
Public propertyBorderColorOverrides the WebControl..::.BorderColor property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.BorderColor.)
Public propertyBorderStyleOverrides the WebControl..::.BorderStyle property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.BorderStyle.)
Public propertyBorderWidthOverrides the WebControl..::.BorderWidth property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.BorderWidth.)
Protected propertyChildControlsCreatedGets a value that indicates whether the server control's child controls have been created. (Inherited from Control.)
Public propertyClientIDGets the control ID for HTML markup that is generated by ASP.NET. (Inherited from Control.)
Public propertyClientIDModeGets or sets the algorithm that is used to generate the value of the ClientID property. (Inherited from Control.)
Public propertyClientIDRowSuffixGets or sets the name of the data field whose value is used to uniquely identify each data row of a ListView control when the ClientIDMode property is set to Predictable.
Public propertyClientIDRowSuffixDataKeysInfrastructure. Gets the data values that are used to uniquely identify each instance of a data-bound control when ASP.NET generates the ClientID value.
Protected propertyClientIDSeparatorGets a character value representing the separator character used in the ClientID property. (Inherited from Control.)
Protected propertyContextGets the HttpContext object associated with the server control for the current Web request. (Inherited from Control.)
Public propertyControlsGets a ControlCollection object that represents the child controls of the ListView control. (Overrides Control..::.Controls.)
Public propertyControlStyleGets the style of the Web server control. This property is used primarily by control developers. (Inherited from WebControl.)
Public propertyControlStyleCreatedGets a value indicating whether a Style object has been created for the ControlStyle property. This property is primarily used by control developers. (Inherited from WebControl.)
Public propertyConvertEmptyStringToNullGets or sets a value that indicates whether empty string values ("") are automatically converted to null values when the data field is updated in the data source.
Public propertyCssClassOverrides the WebControl..::.CssClass property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.CssClass.)
Public propertyDataItemContainerGets a reference to the naming container if the naming container implements IDataItemContainer. (Inherited from Control.)
Public propertyDataKeyNamesGets or sets an array that contains the names of the primary key fields for the items displayed in a ListView control.
Public propertyDataKeysGets a collection of DataKey objects that represent the data-key value for each item in a ListView control.
Public propertyDataKeysContainerGets a reference to the naming container if the naming container implements IDataKeysControl. (Inherited from Control.)
Public propertyDataMemberGets or sets the name of the list of data that the data-bound control binds to, in cases where the data source contains more than one distinct list of data items. (Inherited from DataBoundControl.)
Public propertyDataSourceGets or sets the object from which the data-bound control retrieves its list of data items. (Inherited from BaseDataBoundControl.)
Public propertyDataSourceIDGets or sets the ID of the control from which the data-bound control retrieves its list of data items. (Inherited from DataBoundControl.)
Public propertyDataSourceObjectGets an object that implements the IDataSource interface, which provides access to the object's data content. (Inherited from DataBoundControl.)
Protected propertyDesignModeGets a value indicating whether a control is being used on a design surface. (Inherited from Control.)
Public propertyEditIndexGets or sets the index of the item being edited.
Public propertyEditItemGets the item that is in edit mode in a ListView control.
Public propertyEditItemTemplateGets or sets the custom content for the item in edit mode.
Public propertyEmptyDataTemplateGets or sets the user-defined content for the empty template that is rendered when a ListView control is bound to a data source that does not contain any records.
Public propertyEmptyItemTemplateGets or sets the user-defined content for the empty item that is rendered in a ListView control when there are no more data items to display in the last row of the current data page.
Public propertyEnabledGets or sets a value indicating whether the Web server control is enabled. (Inherited from WebControl.)
Public propertyEnableModelValidationGets or sets a value that indicates whether a validator control will handle exceptions that occur during insert or update operations.
Public propertyEnablePersistedSelectionGets or sets a value that indicates whether row selection persists when a user pages through data in a data-bound control.
Public propertyEnableThemingGets or sets a value indicating whether themes apply to this control. (Inherited from WebControl.)
Public propertyEnableViewStateGets or sets a value indicating whether the server control persists its view state, and the view state of any child controls it contains, to the requesting client. (Inherited from Control.)
Protected propertyEventsGets a list of event handler delegates for the control. This property is read-only. (Inherited from Control.)
Public propertyFontOverrides the WebControl..::.Font property. This property is not supported by the ListView control. (Overrides WebControl..::.Font.)
Public propertyForeColorOverrides the WebControl..::.ForeColor property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.ForeColor.)
Public propertyGroupItemCountGets or sets the number of items to display per group in a ListView control.
Public propertyGroupPlaceholderIDGets or sets the ID for the group placeholder in a ListView control.
Public propertyGroupSeparatorTemplateGets or sets the user-defined content for the separator between groups in a ListView control.
Public propertyGroupTemplateGets or sets the user-defined content for the group container in a ListView control.
Public propertyHasAttributesGets a value indicating whether the control has attributes set. (Inherited from WebControl.)
Protected propertyHasChildViewStateGets a value indicating whether the current server control's child controls have any saved view-state settings. (Inherited from Control.)
Public propertyHeightOverrides the WebControl..::.Height property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.Height.)
Public propertyIDGets or sets the programmatic identifier assigned to the server control. (Inherited from Control.)
Protected propertyIdSeparatorInfrastructure. Gets the character used to separate control identifiers. (Inherited from Control.)
Protected propertyInitializedGets a value indicating whether the data-bound control has been initialized. (Inherited from BaseDataBoundControl.)
Public propertyInsertItemGets the insert item of a ListView control.
Public propertyInsertItemPositionGets or sets the location of the InsertItemTemplate template when it is rendered as part of the ListView control.
Public propertyInsertItemTemplateGets or sets the custom content for an insert item in the ListView control.
Protected propertyIsBoundUsingDataSourceIDGets a value indicating whether the DataSourceID property is set. (Inherited from BaseDataBoundControl.)
Protected propertyIsChildControlStateClearedGets a value indicating whether controls contained within this control have control state. (Inherited from Control.)
Protected propertyIsEnabledGets a value indicating whether the control is enabled. (Inherited from WebControl.)
Protected propertyIsTrackingViewStateGets a value that indicates whether the server control is saving changes to its view state. (Inherited from Control.)
Protected propertyIsViewStateEnabledGets a value indicating whether view state is enabled for this control. (Inherited from Control.)
Public propertyItemPlaceholderIDGets or sets the ID for the item placeholder in a ListView control.
Public propertyItemsGets a collection of ListViewDataItem objects that represent the data items of the current page of data in a ListView control.
Public propertyItemSeparatorTemplateGets or sets the custom content for the separator between the items in a ListView control.
Public propertyItemTemplateGets or sets the custom content for the data item in a ListView control.
Public propertyLayoutTemplateGets or sets the custom content for the root container in a ListView control.
Protected propertyLoadViewStateByIDGets a value indicating whether the control participates in loading its view state by ID instead of index. (Inherited from Control.)
Protected propertyMaximumRowsGets the maximum number of items to display on a single page of the ListView control.
Public propertyNamingContainerGets a reference to the server control's naming container, which creates a unique namespace for differentiating between server controls with the same Control..::.ID property value. (Inherited from Control.)
Public propertyPageGets a reference to the Page instance that contains the server control. (Inherited from Control.)
Public propertyParentGets a reference to the server control's parent control in the page control hierarchy. (Inherited from Control.)
Public propertyRenderingCompatibilityGets a value that specifies the ASP.NET version that rendered HTML will be compatible with. (Inherited from Control.)
Protected propertyRequiresDataBindingGets or sets a value indicating whether the DataBind method should be called. (Inherited from BaseDataBoundControl.)
Protected propertySelectArgumentsGets a DataSourceSelectArguments object that the data-bound control uses when retrieving data from a data source control. (Inherited from DataBoundControl.)
Public propertySelectedDataKeyGets the data-key value for the selected item in a ListView control.
Public propertySelectedIndexGets or sets the index of the selected item in a ListView control.
Public propertySelectedItemTemplateGets or sets the custom content for the selected item in a ListView control.
Public propertySelectedPersistedDataKeyGets or sets the data-key value for the persisted selected item in a data-bound control.
Public propertySelectedValueGets the data-key value of the selected item in a ListView control.
Public propertySiteGets information about the container that hosts the current control when rendered on a design surface. (Inherited from Control.)
Public propertySkinIDGets or sets the skin to apply to the control. (Inherited from WebControl.)
Public propertySortDirectionGets the sort direction of the field or fields that are being sorted.
Public propertySortExpressionGets the sort expression that is associated with the field or fields that are being sorted.
Protected propertyStartRowIndexGets the index of the first record that is displayed on a page of data in the ListView control.
Public propertyStyleGets a collection of text attributes that will be rendered as a style attribute on the outer tag of the Web server control. (Inherited from WebControl.)
Public propertySupportsDisabledAttributeGets a value that indicates whether the control should set the disabled attribute of the rendered HTML element to "disabled" when the control's IsEnabled property is false. (Inherited from BaseDataBoundControl.)
Public propertyTabIndexOverrides the WebControl..::.TabIndex property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.TabIndex.)
Protected propertyTagKeyGets the HtmlTextWriterTag value that corresponds to this Web server control. This property is used primarily by control developers. (Inherited from WebControl.)
Protected propertyTagNameGets the name of the control tag. This property is used primarily by control developers. (Inherited from WebControl.)
Public propertyTemplateControlGets or sets a reference to the template that contains this control. (Inherited from Control.)
Public propertyTemplateSourceDirectoryGets the virtual directory of the Page or UserControl that contains the current server control. (Inherited from Control.)
Public propertyToolTipOverrides the WebControl..::.ToolTip property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.ToolTip.)
Public propertyUniqueIDGets the unique, hierarchically qualified identifier for the server control. (Inherited from Control.)
Protected propertyViewStateGets a dictionary of state information that allows you to save and restore the view state of a server control across multiple requests for the same page. (Inherited from Control.)
Protected propertyViewStateIgnoresCaseGets a value that indicates whether the StateBag object is case-insensitive. (Inherited from Control.)
Public propertyViewStateModeGets or sets the view-state mode of this control. (Inherited from Control.)
Public propertyVisibleGets or sets a value that indicates whether a server control is rendered as UI on the page. (Inherited from Control.)
Public propertyWidthOverrides the WebControl..::.Width property. Setting this property is not supported by the ListView control. (Overrides WebControl..::.Width.)
Top
  NameDescription
Protected methodAddAttributesToRenderAdds HTML attributes and styles that need to be rendered to the specified HtmlTextWriterTag. This method is used primarily by control developers. (Inherited from WebControl.)
Protected methodAddControlToContainerAdds the specified control to the specified container.
Protected methodAddedControlCalled after a child control is added to the Controls collection of the Control object. (Inherited from Control.)
Protected methodAddParsedSubObjectNotifies the server control that an element, either XML or HTML, was parsed, and adds the element to the server control's ControlCollection object. (Inherited from Control.)
Public methodApplyStyleCopies any nonblank elements of the specified style to the Web control, overwriting any existing style elements of the control. This method is primarily used by control developers. (Inherited from WebControl.)
Public methodApplyStyleSheetSkinApplies the style properties defined in the page style sheet to the control. (Inherited from Control.)
Protected methodBuildProfileTreeInfrastructure. Gathers information about the server control and delivers it to the Trace property to be displayed when tracing is enabled for the page. (Inherited from Control.)
Protected methodClearCachedClientIDInfrastructure. Sets the cached ClientID value to nullNothingnullptra null reference (Nothing in Visual Basic). (Inherited from Control.)
Protected methodClearChildControlStateDeletes the control-state information for the server control's child controls. (Inherited from Control.)
Protected methodClearChildStateDeletes the view-state and control-state information for all the server control's child controls. (Inherited from Control.)
Protected methodClearChildViewStateDeletes the view-state information for all the server control's child controls. (Inherited from Control.)
Protected methodClearEffectiveClientIDModeInfrastructure. Sets the ClientIDMode property of the current control instance and of any child controls to Inherit. (Inherited from Control.)
Protected methodConfirmInitStateSets the initialized state of the data-bound control. (Inherited from BaseDataBoundControl.)
Public methodCopyBaseAttributesCopies the properties not encapsulated by the Style object from the specified Web server control to the Web server control that this method is called from. This method is used primarily by control developers. (Inherited from WebControl.)
Protected methodCreateChildControls()()()Creates the control hierarchy that is used to render the ListView control, based on the values that are stored in view state. (Overrides Control..::.CreateChildControls()()().)
Protected methodCreateChildControls(IEnumerable, Boolean)Creates the control hierarchy that is used to render the ListView control by using the specified data source.
Protected methodCreateControlCollectionCreates a new ControlCollection object to hold the child controls (both literal and server) of the server control. (Inherited from Control.)
Protected methodCreateControlStyleCreates the default style for the control. (Overrides WebControl..::.CreateControlStyle()()().)
Protected methodCreateDataItemCreates a data item in the ListView control.
Protected methodCreateDataSourceSelectArgumentsCreates the DataSourceSelectArguments object that contains the arguments that are passed to the data source. (Overrides DataBoundControl..::.CreateDataSourceSelectArguments()()().)
Protected methodCreateEmptyDataItemCreates the EmptyDataTemplate template in the ListView control.
Protected methodCreateEmptyItemCreates an empty item in the ListView control.
Protected methodCreateInsertItemCreates an insert item in the ListView control.
Protected methodCreateItemCreates a ListViewItem object with the specified type.
Protected methodCreateItemsInGroupsCreates the ListView control hierarchy in groups.
Protected methodCreateItemsWithoutGroupsCreates the ListView control hierarchy without groups.
Protected methodCreateLayoutTemplateCreates the root container in the ListView control.
Protected methodCreateSuffixArrayListInfrastructure. Creates an array of suffixes for ASP.NET to use when it generates the ClientID value.
Public methodDataBind()()()Binds a data source to the invoked server control and all its child controls. (Inherited from BaseDataBoundControl.)
Protected methodDataBind(Boolean)Binds a data source to the invoked server control and all its child controls with an option to raise the DataBinding event. (Inherited from Control.)
Protected methodDataBindChildrenBinds a data source to the server control's child controls. (Inherited from Control.)
Public methodDeleteItemDeletes the record at the specified index from the data source.
Public methodDisposeEnables a server control to perform final clean up before it is released from memory. (Inherited from Control.)
Protected methodEnsureChildControlsDetermines whether the server control contains child controls. If it does not, it creates child controls. (Inherited from Control.)
Protected methodEnsureDataBoundCalls the DataBind method if the DataSourceID property is set and the data-bound control is marked to require binding. (Inherited from BaseDataBoundControl.)
Protected methodEnsureIDCreates an identifier for controls that do not have an identifier assigned. (Inherited from Control.)
Protected methodEnsureLayoutTemplateEnsures that the LayoutTemplate content is correctly created in the ListView control.
Public methodEquals(Object)Determines whether the specified Object is equal to the current Object. (Inherited from Object.)
Public methodExtractItemValuesRetrieves the values of each field that is declared in the specified item, and stores them in the specified IOrderedDictionary object.
Protected methodFinalizeAllows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection. (Inherited from Object.)
Public methodFindControl(String)Searches the current naming container for a server control with the specified id parameter. (Inherited from Control.)
Protected methodFindControl(String, Int32)Infrastructure. Searches the current naming container for a server control with the specified id and an integer, specified in the pathOffset parameter, which aids in the search. You should not override this version of the FindControl method. (Inherited from Control.)
Protected methodFindPlaceholderSearches the specified container for a control that has the specified identifier.
Public methodFocusSets input focus to a control. (Inherited from Control.)
Protected methodGetDataRetrieves a DataSourceView object that the data-bound control uses to perform data operations. (Inherited from DataBoundControl.)
Protected methodGetDataSourceRetrieves the IDataSource interface that the data-bound control is associated with, if any. (Inherited from DataBoundControl.)
Protected methodGetDesignModeStateInfrastructure. Gets design-time data for a control. (Inherited from Control.)
Public methodGetHashCodeServes as a hash function for a particular type. (Inherited from Object.)
Public methodGetRouteUrl(Object)Gets the URL that corresponds to a set of route parameters. (Inherited from Control.)
Public methodGetRouteUrl(RouteValueDictionary)Gets the URL that corresponds to a set of route parameters. (Inherited from Control.)
Public methodGetRouteUrl(String, Object)Gets the URL that corresponds to a set of route parameters and a route name. (Inherited from Control.)
Public methodGetRouteUrl(String, RouteValueDictionary)Gets the URL that corresponds to a set of route parameters and a route name. (Inherited from Control.)
Public methodGetTypeGets the Type of the current instance. (Inherited from Object.)
Public methodGetUniqueIDRelativeToReturns the prefixed portion of the UniqueID property of the specified control. (Inherited from Control.)
Public methodHasControlsDetermines if the server control contains any child controls. (Inherited from Control.)
Protected methodHasEventsReturns a value indicating whether events are registered for the control or any child controls. (Inherited from Control.)
Public methodInsertNewItemInserts the current record in the data source.
Protected methodInstantiateEmptyDataTemplatePopulates the specified Control object by using the child controls that are contained in the EmptyDataTemplate template.
Protected methodInstantiateEmptyItemTemplatePopulates the specified Control object by using the child controls that are contained in the EmptyItemTemplate template.
Protected methodInstantiateGroupSeparatorTemplatePopulates the specified Control object by using the child controls that are contained in the GroupSeparatorTemplate template.
Protected methodInstantiateGroupTemplatePopulates the specified Control object by using the child controls that are contained in the GroupTemplate template.
Protected methodInstantiateInsertItemTemplatePopulates the specified Control object by using the child controls that are contained in the InsertItemTemplate template.
Protected methodInstantiateItemSeparatorTemplatePopulates the specified Control object by using the child controls that are contained in the ItemSeparatorTemplate template.
Protected methodInstantiateItemTemplatePopulates the specified Control object by using child controls from one of the ListView control templates.
Protected methodIsLiteralContentInfrastructure. Determines if the server control holds only literal content. (Inherited from Control.)
Protected methodLoadControlStateLoads the state of the properties in the ListView control that must be persisted, even when the EnableViewState property is set to false. (Overrides Control..::.LoadControlState(Object).)
Protected methodLoadViewStateLoads the previously saved view state of the ListView control. (Overrides WebControl..::.LoadViewState(Object).)
Protected methodMapPathSecureRetrieves the physical path that a virtual path, either absolute or relative, maps to. (Inherited from Control.)
Protected methodMarkAsDataBoundSets the state of the control in view state as successfully bound to data. (Inherited from DataBoundControl.)
Protected methodMemberwiseCloneCreates a shallow copy of the current Object. (Inherited from Object.)
Public methodMergeStyleCopies any nonblank elements of the specified style to the Web control, but will not overwrite any existing style elements of the control. This method is used primarily by control developers. (Inherited from WebControl.)
Protected methodOnBubbleEventDetermines whether an event for the ListView control should be handled. (Overrides Control..::.OnBubbleEvent(Object, EventArgs).)
Protected methodOnDataBindingRaises the DataBinding event. (Inherited from Control.)
Protected methodOnDataBoundRaises the DataBound event. (Inherited from BaseDataBoundControl.)
Protected methodOnDataPropertyChangedRebinds the data-bound control to its data after one of the base data source identification properties changes. (Inherited from DataBoundControl.)
Protected methodOnDataSourceViewChangedRaises the DataSourceViewChanged event. (Inherited from DataBoundControl.)
Protected methodOnInitRaises the Init event. (Overrides BaseDataBoundControl..::.OnInit(EventArgs).)
Protected methodOnItemCancelingRaises the ItemCanceling event.
Protected methodOnItemCommandRaises the ItemCommand event.
Protected methodOnItemCreatedRaises the ItemCreated event.
Protected methodOnItemDataBoundRaises the ItemDataBound event.
Protected methodOnItemDeletedRaises the ItemDeleted event.
Protected methodOnItemDeletingRaises the ItemDeleting event.
Protected methodOnItemEditingRaises the ItemEditing event.
Protected methodOnItemInsertedRaises the ItemInserted event.
Protected methodOnItemInsertingRaises the ItemInserting event.
Protected methodOnItemUpdatedRaises the ItemUpdated event.
Protected methodOnItemUpdatingRaises the ItemUpdating event.
Protected methodOnLayoutCreatedRaises the LayoutCreated event.
Protected methodOnLoadHandles the Control..::.Load event. (Inherited from DataBoundControl.)
Protected methodOnPagePreLoadSets the initialized state of the data-bound control before the control is loaded. (Inherited from DataBoundControl.)
Protected methodOnPagePropertiesChangedRaises the PagePropertiesChanged event.
Protected methodOnPagePropertiesChangingRaises the PagePropertiesChanging event.
Protected methodOnPreRenderHandles the PreRender event. (Inherited from BaseDataBoundControl.)
Protected methodOnSelectedIndexChangedRaises the SelectedIndexChanged event.
Protected methodOnSelectedIndexChangingRaises the SelectedIndexChanging event.
Protected methodOnSortedRaises the Sorted event.
Protected methodOnSortingRaises the Sorting event.
Protected methodOnTotalRowCountAvailableRaises the IPageableItemContainer..::.TotalRowCountAvailable event.
Protected methodOnUnloadRaises the Unload event. (Inherited from Control.)
Protected methodOpenFileGets a Stream used to read a file. (Inherited from Control.)
Protected methodPerformDataBindingBinds the ListView control to the specified data source. (Overrides DataBoundControl..::.PerformDataBinding(IEnumerable).)
Protected methodPerformSelectRetrieves data from the associated data source. (Overrides DataBoundControl..::.PerformSelect()()().)
Protected methodRaiseBubbleEventAssigns any sources of the event and its information to the control's parent. (Inherited from Control.)
Protected methodRemovedControlCalled after a child control is removed from the Controls collection of the Control object. (Inherited from Control.)
Protected methodRemoveItemsDeletes all child controls in an item or group container of the ListView control.
Protected methodRenderRenders the Web server control content to the client's browser by using the specified HtmlTextWriter object. (Overrides WebControl..::.Render(HtmlTextWriter).)
Public methodRenderBeginTagRenders the HTML opening tag of the control to the specified writer. This method is used primarily by control developers. (Inherited from WebControl.)
Protected methodRenderChildrenOutputs the content of a server control's children to a provided HtmlTextWriter object, which writes the content to be rendered on the client. (Inherited from Control.)
Protected methodRenderContentsRenders the contents of the control to the specified writer. This method is used primarily by control developers. (Inherited from WebControl.)
Public methodRenderControl(HtmlTextWriter)Outputs server control content to a provided HtmlTextWriter object and stores tracing information about the control if tracing is enabled. (Inherited from Control.)
Protected methodRenderControl(HtmlTextWriter, ControlAdapter)Outputs server control content to a provided HtmlTextWriter object using a provided ControlAdapter object. (Inherited from Control.)
Public methodRenderEndTagRenders the HTML closing tag of the control into the specified writer. This method is used primarily by control developers. (Inherited from WebControl.)
Protected methodResolveAdapterGets the control adapter responsible for rendering the specified control. (Inherited from Control.)
Public methodResolveClientUrlGets a URL that can be used by the browser. (Inherited from Control.)
Public methodResolveUrlConverts a URL into one that is usable on the requesting client. (Inherited from Control.)
Protected methodSaveControlStateSaves the state of the properties in the ListView control that must be persisted, even when the EnableViewState property is set to false. (Overrides Control..::.SaveControlState()()().)
Protected methodSaveViewStateSaves the current view state of the ListView control. (Overrides WebControl..::.SaveViewState()()().)
Public methodSelectItemSelects the item that is in edit mode in a ListView control.
Protected methodSetDesignModeStateSets design-time data for a control. (Inherited from Control.)
Public methodSetEditItemSets the specified item into edit mode in a ListView control.
Protected methodSetPagePropertiesSets the properties of a page of data in the ListView control.
Public methodSetRenderMethodDelegateInfrastructure. Assigns an event handler delegate to render the server control and its content into its parent control. (Inherited from Control.)
Public methodSortSorts the ListView control, depending on the specified sort expression and direction.
Public methodToStringReturns a string that represents the current object. (Inherited from Object.)
Protected methodTrackViewStateCauses the control to track changes to its view state so they can be stored in the object's ViewState property. (Inherited from WebControl.)
Public methodUpdateItemUpdates the record at the specified index in the data source.
Protected methodValidateDataSourceVerifies that the object a data-bound control binds to is one it can work with. (Inherited from DataBoundControl.)
Top
  NameDescription
Public eventDataBindingOccurs when the server control binds to a data source. (Inherited from Control.)
Public eventDataBoundOccurs after the server control binds to a data source. (Inherited from BaseDataBoundControl.)
Public eventDisposedOccurs when a server control is released from memory, which is the last stage of the server control lifecycle when an ASP.NET page is requested. (Inherited from Control.)
Public eventInitOccurs when the server control is initialized, which is the first step in its lifecycle. (Inherited from Control.)
Public eventItemCancelingOccurs when a cancel operation is requested, but before the ListView control cancels the insert or edit operation.
Public eventItemCommandOccurs when a button in a ListView control is clicked.
Public eventItemCreatedOccurs when an item is created in a ListView control.
Public eventItemDataBoundOccurs when a data item is bound to data in a ListView control.
Public eventItemDeletedOccurs when a delete operation is requested, after the ListView control deletes the item.
Public eventItemDeletingOccurs when a delete operation is requested, but before the ListView control deletes the item.
Public eventItemEditingOccurs when an edit operation is requested, but before the ListView item is put in edit mode.
Public eventItemInsertedOccurs when an insert operation is requested, after the ListView control has inserted the item in the data source.
Public eventItemInsertingOccurs when an insert operation is requested, but before the ListView control performs the insert.
Public eventItemUpdatedOccurs when an update operation is requested, after the ListView control updates the item.
Public eventItemUpdatingOccurs when an update operation is requested, but before the ListView control updates the item.
Public eventLayoutCreatedOccurs when the LayoutTemplate template is created in a ListView control.
Public eventLoadOccurs when the server control is loaded into the Page object. (Inherited from Control.)
Public eventPagePropertiesChangedOccurs when the page properties change, after the ListView control sets the new values.
Public eventPagePropertiesChangingOccurs when the page properties change, but before the ListView control sets the new values.
Public eventPreRenderOccurs after the Control object is loaded but prior to rendering. (Inherited from Control.)
Public eventSelectedIndexChangedOccurs when an item's Select button is clicked, after the ListView control handles the select operation.
Public eventSelectedIndexChangingOccurs when an item's Select button is clicked, but before the ListView control handles the select operation.
Public eventSortedOccurs when a sort operation is requested, after the ListView control handles the sort operation.
Public eventSortingOccurs when a sort operation is requested, but before the ListView control handles the sort operation.
Public eventUnloadOccurs when the server control is unloaded from memory. (Inherited from Control.)
Top
  NameDescription
Public Extension MethodEnableDynamicData(Type)Overloaded. Enables Dynamic Data behavior for the specified data control. (Defined by DataControlExtensions.)
Public Extension MethodEnableDynamicData(Type, Object)Overloaded. Enables Dynamic Data behavior for the specified data control. (Defined by DataControlExtensions.)
Public Extension MethodEnableDynamicData(Type, IDictionary<(Of <(String, Object>)>))Overloaded. Enables Dynamic Data behavior for the specified data control. (Defined by DataControlExtensions.)
Public Extension MethodEnablePersistedSelectionEnables selection to be persisted in data controls that support selection and paging. (Defined by DynamicDataExtensions.)
Public Extension MethodFindDataSourceControlReturns the data source that is associated with the data control for the specified control. (Defined by DynamicDataExtensions.)
Public Extension MethodFindFieldTemplateReturns the field template for the specified column in the specified control's naming container. (Defined by DynamicDataExtensions.)
Public Extension MethodFindMetaTableReturns the metatable object for the containing data control. (Defined by DynamicDataExtensions.)
Public Extension MethodGetDefaultValuesGets the collection of the default values for the specified data control. (Defined by DynamicDataExtensions.)
Public Extension MethodGetMetaTableGets the table metadata for the specified data control. (Defined by DynamicDataExtensions.)
Public Extension MethodSetMetaTable(MetaTable)Overloaded. Sets the table metadata for the specified data control. (Defined by DynamicDataExtensions.)
Public Extension MethodSetMetaTable(MetaTable, IDictionary<(Of <(String, Object>)>))Overloaded. Sets the table metadata and default value mapping for the specified data control. (Defined by DynamicDataExtensions.)
Public Extension MethodSetMetaTable(MetaTable, Object)Overloaded. Sets the table metadata and default value mapping for the specified data control. (Defined by DynamicDataExtensions.)
Public Extension MethodTryGetMetaTableDetermines whether table metadata is available. (Defined by DynamicDataExtensions.)
Top
  NameDescription
Explicit interface implemetationPrivate methodIAttributeAccessor..::.GetAttributeInfrastructure. Gets an attribute of the Web control with the specified name. (Inherited from WebControl.)
Explicit interface implemetationPrivate methodIAttributeAccessor..::.SetAttributeSets an attribute of the Web control to the specified name and value. (Inherited from WebControl.)
Explicit interface implemetationPrivate propertyIControlBuilderAccessor..::.ControlBuilderFor a description of this member, see IControlBuilderAccessor..::.ControlBuilder. (Inherited from Control.)
Explicit interface implemetationPrivate methodIControlDesignerAccessor..::.GetDesignModeStateFor a description of this member, see IControlDesignerAccessor..::.GetDesignModeState. (Inherited from Control.)
Explicit interface implemetationPrivate methodIControlDesignerAccessor..::.SetDesignModeStateFor a description of this member, see IControlDesignerAccessor..::.SetDesignModeState. (Inherited from Control.)
Explicit interface implemetationPrivate methodIControlDesignerAccessor..::.SetOwnerControlInfrastructure. For a description of this member, see IControlDesignerAccessor..::.SetOwnerControl. (Inherited from Control.)
Explicit interface implemetationPrivate propertyIControlDesignerAccessor..::.UserDataFor a description of this member, see IControlDesignerAccessor..::.UserData. (Inherited from Control.)
Explicit interface implemetationPrivate propertyIDataBindingsAccessor..::.DataBindingsFor a description of this member, see IDataBindingsAccessor..::.DataBindings. (Inherited from Control.)
Explicit interface implemetationPrivate propertyIDataBindingsAccessor..::.HasDataBindingsFor a description of this member, see IDataBindingsAccessor..::.HasDataBindings. (Inherited from Control.)
Explicit interface implemetationPrivate propertyIDataBoundControl..::.DataKeyNamesGets or sets an array that contains the names of the primary-key fields of the items that are displayed in a data-bound control.
Explicit interface implemetationPrivate propertyIDataBoundControl..::.DataMemberGets or sets the name of the list of data that the data-bound control binds to when the data source contains more than one distinct list of data items.
Explicit interface implemetationPrivate propertyIDataBoundControl..::.DataSourceGets or sets the object from which a data-bound control retrieves its list of data items.
Explicit interface implemetationPrivate propertyIDataBoundControl..::.DataSourceIDGets or sets the ID of the data source control from which a data-bound control retrieves its list of data items.
Explicit interface implemetationPrivate propertyIDataBoundControl..::.DataSourceObjectGets an object that implements the IDataSource interface, which provides access to the object's data content.
Explicit interface implemetationPrivate propertyIDataBoundListControl..::.ClientIDRowSuffixGets the name of the data field whose value is used to uniquely identify each data row of a ListView control when the ClientIDMode property is set to Predictable.
Explicit interface implemetationPrivate propertyIDataBoundListControl..::.DataKeysGets a collection of data-key values that represent each row in a data-bound control.
Explicit interface implemetationPrivate propertyIDataBoundListControl..::.EnablePersistedSelectionGets or sets the value that specifies whether a selected row persists when a user pages through data in a data-bound control.
Explicit interface implemetationPrivate propertyIDataBoundListControl..::.SelectedDataKeyGets the data-key object that contains the data-key value for the selected row in a data-bound control.
Explicit interface implemetationPrivate propertyIDataBoundListControl..::.SelectedIndexGets or sets the index of the selected row in a data-bound control.
Explicit interface implemetationPrivate propertyIDataKeysControl..::.ClientIDRowSuffixDataKeysInfrastructure. Gets a collection of the data values that are used to uniquely identify each instance of a data-bound control when ASP.NET generates the ClientID value.
Explicit interface implemetationPrivate propertyIExpressionsAccessor..::.ExpressionsFor a description of this member, see IExpressionsAccessor..::.Expressions. (Inherited from Control.)
Explicit interface implemetationPrivate propertyIExpressionsAccessor..::.HasExpressionsFor a description of this member, see IExpressionsAccessor..::.HasExpressions. (Inherited from Control.)
Explicit interface implemetationPrivate propertyIPageableItemContainer..::.MaximumRowsInfrastructure. For a description of this member, see IPageableItemContainer..::.MaximumRows.
Explicit interface implemetationPrivate methodIPageableItemContainer..::.SetPagePropertiesInfrastructure. For a description of this member, see IPageableItemContainer..::.SetPageProperties.
Explicit interface implemetationPrivate propertyIPageableItemContainer..::.StartRowIndexInfrastructure. For a description of this member, see IPageableItemContainer..::.StartRowIndex.
Explicit interface implemetationPrivate eventIPageableItemContainer..::.TotalRowCountAvailableInfrastructure. For a description of this member, see IPageableItemContainer..::.TotalRowCountAvailable.
Explicit interface implemetationPrivate methodIParserAccessor..::.AddParsedSubObjectFor a description of this member, see IParserAccessor..::.AddParsedSubObject. (Inherited from Control.)
Explicit interface implemetationPrivate propertyIPersistedSelector..::.DataKeyGets or sets the data-key value for the selected record in a data-bound control.
Top

In this topic:

Introduction

The ListView control is used to display the values from a data source. It resembles the GridView control, except that it displays data by using user-defined templates instead of row fields. Creating your own templates gives you more flexibility in controlling how the data is displayed.

A Visual Studio project with source code is available to accompany this topic: Download.

The ListView control supports the following features:

  • Support for binding to data source controls such as SqlDataSource, LinqDataSource, and ObjectDataSource.

  • Customizable appearance through user-defined templates and styles.

  • Built-in sorting capabilities.

  • Built-in update and delete capabilities.

  • Built-in insert capabilities.

  • Support for paging capabilities by using a DataPager control.

  • Built-in item selection capabilities.

  • Programmatic access to the ListView object model to dynamically set properties, handle events, and so on.

  • Multiple key fields.

To learn about other data-bound controls that are available in ASP.NET, see ASP.NET Data-Bound Web Server Controls Overview.

Templates

In order for the ListView control to display content, you must create templates for different parts of the control. The ItemTemplate is required. All other templates are optional. The LayoutTemplate property is not required.

However, you must create a template for the mode in which the control is configured. For example, a ListView control that supports inserting records must have an InsertItemTemplate template defined. The following table lists the templates that you can create for the ListView control.

Template type

Description

LayoutTemplate

The root template that defines a container object, such as a table, div, or span element, that will contain the content defined in the ItemTemplate or GroupTemplate template. It might also contain a DataPager object.

ItemTemplate

Defines the data-bound content to display for individual items.

ItemSeparatorTemplate

Defines the content to render between individual items.

GroupTemplate

Defines a container object, such as a table row (tr), div, or span element, that will contain the content defined in the ItemTemplate and EmptyItemTemplate templates. The number of items that are displayed in a group is specified by the GroupItemCount property.

GroupSeparatorTemplate

Defines the content to render between groups of items.

EmptyItemTemplate

Defines the content to render for an empty item when a GroupTemplate template is used. For example, if the GroupItemCount property is set to 5, and the total number of items returned from the data source is 8, the last group of data displayed by the ListView control will contain three items as specified by the ItemTemplate template, and two items as specified by the EmptyItemTemplate template.

EmptyDataTemplate

Defines the content to render if the data source returns no data.

SelectedItemTemplate

Defines the content to render for the selected data item to differentiate the selected item from other items.

AlternatingItemTemplate

Defines the content to render for alternating items to make it easier to distinguish between consecutive items.

EditItemTemplate

Defines the content to render when an item is being edited. The EditItemTemplate template is rendered in place of the ItemTemplate template for the data item that is being edited.

InsertItemTemplate

Defines the content to render to insert an item. The InsertItemTemplate template is rendered in place of an ItemTemplate template at either the start or at the end of the items that are displayed by the ListView control. You can specify where the InsertItemTemplate template is rendered by using the InsertItemPosition property of the ListView control.

To display the value of a field in a template such as ItemTemplate, you use a data-binding expression. For more information about data-binding expressions, see Data-Binding Expressions Overview.

To bind input controls in the EditItemTemplate and InsertItemTemplate templates to fields of a data source, you can use two-way binding expressions. This enables the ListView control to automatically extract the values of the input control for an update or insert operation. Two-way binding expressions also enable input controls in an EditItemTemplate to automatically display the original field values. For more information about two-way binding expressions, see Binding to Databases.

Binding to a Data Source

You can bind the ListView control to a data source control (such as the SqlDataSource control or ObjectDataSource control) or to any data source collection that implements the System.Collections..::.IEnumerable interface, such as System.Data..::.DataView, System.Collections..::.ArrayList, System.Collections.Generic..::.List<(Of <(T>)>), or other collection types. Use one of the following methods to bind the ListView control to the appropriate data source type:

  • To bind to a data source control, set the DataSourceID property of the ListView control to the ID value of the data source control. The ListView control automatically binds to the specified data source control and can take advantage of the data source control's capabilities to perform sorting, inserting, updating, deleting, and paging functionality. This is the preferred method to bind to data.

  • To bind to a data source that implements the System.Collections..::.IEnumerable interface, programmatically set the DataSource property of the ListView control to the data source, and then call the DataBind method. When you use this technique, the ListView control does not provide built-in sorting, updating, deleting, and paging functionality. You must provide this functionality by using the appropriate event.

For more information about data binding, see ASP.NET Data Access.

NoteNote

The ListView control can be used to display user input, which might include malicious client script. Check any information that is sent from a client for executable script, SQL statements, or other code before you display it in the application. We strongly recommend that values be HTML-encoded whenever possible before they are displayed in this control. ASP.NET provides an input request validation feature to help block script and HTML in user input. You can also use validation server controls to check user input. For more information, see Introduction to the Validation Controls.

Data Operations

When the ListView control is bound to a data source control, the ListView control can take advantage of the data source control's capabilities and provide automatic sort, insert, update, and delete functionality.

NoteNote

The ListView control can provide support for sorting, inserting, updating, and deleting with other types of data sources. However, in order to implement these operations, you must create code in an appropriate event handler.

Because the ListView control uses templates, it does not provide a way to automatically generate buttons to perform update, delete, insert, sort, or select operations. You must manually include these buttons in the appropriate template. The ListView control recognizes certain buttons whose CommandName property is set to a specific value. The following table lists the buttons that the ListView control recognizes and their functions.

Button

CommandName value

Description

Cancel

"Cancel"

Cancels an edit or insert operation. Raises the ItemCanceling event.

Delete

"Delete"

Deletes the current record from the data source. Raises the ItemDeleted and ItemDeleting events.

Select

"Select"

Sets the SelectedIndex property to the DisplayIndex property value for the item. Renders the SelectedItemTemplate template for the item. Raises the SelectedIndexChanging and SelectedIndexChanged events.

Edit

"Edit"

Puts the item in edit mode. Renders the EditItemTemplate template for the item. Raises the ItemEditing event.

Insert

"Insert"

Inserts the bound values from the InsertItemTemplate template into the data source. Raises the ItemInserting and ItemInserted events.

Update

"Update"

Updates the current record in the data source with the bound values from the EditItemTemplate template. Raises the ItemUpdating and ItemUpdated events.

Sort

"Sort"

Sorts the columns listed in the CommandArgument property of the button. Raises the Sorting and Sorted events.

Unlike the Delete button (which deletes the current data item immediately), when the Edit button is clicked, the ListView control displays the current item in edit mode. In edit mode, the content that is contained in the EditItemTemplate property is displayed for the current data item. Typically, in the edit item template, the Edit button is replaced with an Update and a Cancel button. Input controls that are appropriate for the field's data type (such as a TextBox or CheckBox control) also usually display a field's value for a user to modify. Clicking the Update button updates the record in the data source, and clicking the Cancel button cancels the edit operation.

The insert functionality is enabled when the InsertItemPosition property is set to FirstItem or LastItem. This property defines where the InsertItemTemplate template is rendered for the insert item. The insert item template typically includes an Insert and a Cancel button, and empty input controls are displayed for users to enter the values for the new record. Clicking the Insert button inserts the record in the data source, and clicking the Cancel button clears all the fields.

Sorting

The ListView control enables users to sort the items by clicking the Sort button. Sort functionality is defined in the CommandArgument property of the button that contains the columns to be sorted.

Paging

Instead of displaying all the records from the data source at the same time, the ListView control can break the records into pages. To enable paging, associate a DataPager control with the ListView control. Then insert a DataPager control inside the LayoutTemplate template. Alternatively, if the DataPager control is outside the ListView control, set the PagedControlID property to the ID of the ListView control.

Events

The following table lists the events that are supported by the ListView control.

Event

Description

ItemCanceling

Occurs when the Cancel button (a button with its CommandName property set to "Cancel") is clicked, but before the ListView control cancels the insert or edit operation. This event is often used to stop the cancel operation.

ItemCommand

Occurs when a button is clicked in the ListView control. This event is often used to perform a custom task when a button is clicked in the control.

ItemCreated

Occurs when a new item is created in the ListView control. This event is often used to modify the content of an item when the item is created.

ItemDataBound

Occurs when a data item is bound to data in the ListView control. This event is often used to modify the content of an item when the item is bound to data.

ItemDeleted

Occurs when a Delete button (a button with its CommandName property set to "Delete") is clicked or the DeleteItem method is called, after the ListView control deletes the record from the data source. This event is often used to check the results of the delete operation.

ItemDeleting

Occurs when a Delete button (a button with its CommandName property set to "Delete") is clicked or the DeleteItem method is called, but before the ListView control deletes the record from the data source. This event is often used to confirm or cancel the delete operation.

ItemEditing

Occurs when an Edit button (a button with its CommandName property set to "Edit") is clicked, but before the ListView control enters edit mode. This event is often used to cancel the editing operation.

ItemInserted

Occurs when an Insert button (a button with its CommandName property set to "Insert") is clicked or the InsertNewItem method is called, after the ListView control inserts the new record from the data source. This event is often used to check the results of the insert operation.

ItemInserting

Occurs when an Insert button (a button with its CommandName property set to "Insert") is clicked or the InsertNewItem method is called, but before the ListView control inserts the record. This event is often used to cancel the insert operation or change or validate the values of the new item.

ItemUpdated

Occurs when an Update button (a button with its CommandName property set to "Update") is clicked or the UpdateItem method is called, after the ListView control updates the record. This event is often used to check the results of the update operation.

ItemUpdating

Occurs when an Update button (a button with its CommandName property set to "Update") is clicked or the UpdateItem method is called, but before the ListView control updates the record. This event is often used to cancel the updating operation or change or validate the values of the edited item.

LayoutCreated

Occurs when the LayoutTemplate template is created in a ListView control. This event is often used to perform a task after the template is created.

PagePropertiesChanged

Occurs when the page properties change, after the ListView control sets the new values.

PagePropertiesChanging

Occurs when the data-page properties change, but before the ListView control sets the new values.

SelectedIndexChanged

Occurs when a Select button (a button with its CommandName property set to "Select") is clicked, after the ListView control handles the select operation. This event is often used to perform a custom task after an item is selected in the control.

SelectedIndexChanging

Occurs when a Select button (a button with its CommandName property set to "Select") is clicked, but before the ListView control handles the select operation. This event is often used to cancel the select operation.

Sorted

Occurs when a Sort button (a button with its CommandName property set to "Sort") is clicked or the Sort method is called, after the ListView control handles the sort operation. This event is typically used to perform a custom task after a user clicks a Sort button and the data has been sorted.

Sorting

Occurs when a Sort button (a button with its CommandName property set to "Sort") is clicked or the Sort method is called, but before the ListView control handles the sort operation. This event is often used to cancel the sorting operation or to perform a custom sorting routine.

Declarative Syntax

<asp:ListView
    ConvertEmptyStringToNull="True|False"
    DataKeyNames="string"
    DataMember="string"
    DataSource="string"
    DataSourceID="string"
    EditIndex="integer"
    Enabled="True|False"
    EnableTheming="True|False"
    EnableViewState="True|False"
    GroupPlaceholderID="string"
    GroupItemCount="integer"
    ID="string"
    InsertItemPosition="None|FirstItem|LastItem"
    ItemPlaceholderID="string"
    OnDataBinding="DataBinding event handler"
    OnDataBound="DataBound event handler"
    OnDisposed="Disposed event handler"
    OnInit="Init event handler"
    OnItemCanceling="ItemCanceling event handler"
    OnItemCommand="ItemCommand event handler"
    OnItemCreated="ItemCreated event handler"
    OnItemDataBound="ItemDataBound event handler"
    OnItemDeleted="ItemDeleted event handler"
    OnItemDeleting="ItemDeleting event handler"
    OnItemEditing="ItemEditing event handler"
    OnItemInserted="ItemInserted event handler"
    OnItemInserting="ItemInserting event handler"
    OnItemUpdated="ItemUpdated event handler"
    OnItemUpdating="ItemUpdating event handler"
    OnLayoutCreated="LayoutCreated event handler"
    OnLoad="Load event handler"
    OnPagePropertiesChanged="PagePropertiesChanged event handler"
    OnPagePropertiesChanging="PagePropertiesChanging event handler"
    OnPreRender="PreRender event handler"
    OnSelectedIndexChanged="SelectedIndexChanged event handler"
    OnSelectedIndexChanging="SelectedIndexChanging event handler"
    OnSorted="Sorted event handler"
    OnSorting="Sorting event handler"
    OnUnload="Unload event handler"
    runat="server"
    SelectedIndex="integer"
    SkinID="string"
    Style="string"
    Visible="True|False"
>
        <AlternatingItemTemplate>
            <!-- child controls -->
        </AlternatingItemTemplate>
        <EditItemTemplate>
            <!-- child controls -->
        </EditItemTemplate>
        <EmptyDataTemplate>
            <!-- child controls -->
        </EmptyDataTemplate>
        <EmptyItemTemplate>
            <!-- child controls -->
        </EmptyItemTemplate>
        <GroupSeparatorTemplate>
            <!-- child controls -->
        </GroupSeparatorTemplate>
        <GroupTemplate>
            <!-- child controls -->
        </GroupTemplate>
        <InsertItemTemplate>
            <!-- child controls -->
        </InsertItemTemplate>
        <ItemSeparatorTemplate>
            <!-- child controls -->
        </ItemSeparatorTemplate>
        <ItemTemplate>
            <!-- child controls -->
        </ItemTemplate>
        <LayoutTemplate>
                <!-- child controls -->
        </LayoutTemplate>
        <SelectedItemTemplate>
            <!-- child controls -->
        </SelectedItemTemplate>
</asp:ListView>

The following example shows how to use the ListView control to display records from a database by using an HTML table. The values are retrieved by using a LinqDataSource control.

Visual Basic
<%@ Page language="VB" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Example</title>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Example</h3>

      <asp:ListView ID="VendorsListView"
        DataSourceID="VendorsDataSource"
        DataKeyNames="VendorID"
        runat="server">
        <LayoutTemplate>
          <table cellpadding="2" width="640px" border="1" ID="tbl1" runat="server">
            <tr runat="server" style="background-color: #98FB98">
              <th runat="server">ID</th>
              <th runat="server">Account Number</th>
              <th runat="server">Name</th>
              <th runat="server">Preferred Vendor</th>
            </tr>
            <tr runat="server" id="itemPlaceholder" />
          </table>
          <asp:DataPager ID="DataPager1" runat="server">
            <Fields>
              <asp:NumericPagerField />
            </Fields>
          </asp:DataPager>
        </LayoutTemplate>
        <ItemTemplate>
          <tr runat="server">
            <td>
              <asp:Label ID="VendorIDLabel" runat="server" Text='<%# Eval("VendorID") %>' />
            </td>
            <td>
              <asp:Label ID="AccountNumberLabel" runat="server" Text='<%# Eval("AccountNumber") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%# Eval("Name") %>' /></td>
            <td>
              <asp:CheckBox ID="PreferredCheckBox" runat="server" 
                Checked='<%# Eval("PreferredVendorStatus") %>' Enabled="False" />
            </td>
          </tr>
        </ItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects   -->
      <!-- to the AdventureWorks sample database. Add a LINQ     -->
      <!-- to SQL class to the project to map to a table in      -->
      <!-- the database.                                         -->
      <asp:LinqDataSource ID="VendorsDataSource" runat="server" 
        ContextTypeName="AdventureWorksClassesDataContext" 
        Select="new (VendorID, AccountNumber, Name, PreferredVendorStatus)" 
        TableName="Vendors" Where="ActiveFlag == @ActiveFlag">
        <WhereParameters>
          <asp:Parameter DefaultValue="true" Name="ActiveFlag" Type="Boolean" />
        </WhereParameters>
      </asp:LinqDataSource>

    </form>
  </body>
</html>
C#
<%@ Page language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Example</title>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Example</h3>

      <asp:ListView ID="VendorsListView"
        DataSourceID="VendorsDataSource"
        DataKeyNames="VendorID"
        runat="server">
        <LayoutTemplate>
          <table cellpadding="2" width="640px" border="1" ID="tbl1" runat="server">
            <tr runat="server" style="background-color: #98FB98">
              <th runat="server">ID</th>
              <th runat="server">Account Number</th>
              <th runat="server">Name</th>
              <th runat="server">Preferred Vendor</th>
            </tr>
            <tr runat="server" id="itemPlaceholder" />
          </table>
          <asp:DataPager ID="DataPager1" runat="server">
            <Fields>
              <asp:NumericPagerField />
            </Fields>
          </asp:DataPager>
        </LayoutTemplate>
        <ItemTemplate>
          <tr runat="server">
            <td>
              <asp:Label ID="VendorIDLabel" runat="server" Text='<%# Eval("VendorID") %>' />
            </td>
            <td>
              <asp:Label ID="AccountNumberLabel" runat="server" Text='<%# Eval("AccountNumber") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%# Eval("Name") %>' /></td>
            <td>
              <asp:CheckBox ID="PreferredCheckBox" runat="server" 
                Checked='<%# Eval("PreferredVendorStatus") %>' Enabled="False" />
            </td>
          </tr>
        </ItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects   -->
      <!-- to the AdventureWorks sample database. Add a LINQ     -->
      <!-- to SQL class to the project to map to a table in      -->
      <!-- the database.                                         -->
      <asp:LinqDataSource ID="VendorsDataSource" runat="server" 
        ContextTypeName="AdventureWorksClassesDataContext" 
        Select="new (VendorID, AccountNumber, Name, PreferredVendorStatus)" 
        TableName="Vendors" Where="ActiveFlag == @ActiveFlag">
        <WhereParameters>
          <asp:Parameter DefaultValue="true" Name="ActiveFlag" Type="Boolean" />
        </WhereParameters>
      </asp:LinqDataSource>

    </form>
  </body>
</html>

The following example shows how to use the ListView control to display values in a flow layout by using the div element. The values are retrieved by using a SqlDataSource control.

Visual Basic
<%@ Page language="VB" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Flow Layout Example</title>
    <style type="text/css">
      .plainBox {
          font-family: Verdana, Arial, sans-serif;
          font-size: 11px;
          background: #ffffff;
          border:1px solid #336666;
          }
    </style>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Flow Layout Example</h3>

      Select the color:
      <asp:DropDownList ID="ColorList" runat="server" 
        AutoPostBack="True" 
        DataSourceID="ColorDataSource" 
        DataTextField="Color" 
        DataValueField="Color">
      </asp:DropDownList><br /><br />

      <asp:ListView runat="server" ID="ProductListView"
        DataSourceID="ProductsDataSource"
        DataKeyNames="ProductID">
        <LayoutTemplate>
          <div runat="server" id="lstProducts">
            <div runat="server" id="itemPlaceholder" />
          </div>
          <asp:DataPager ID="DataPager1" runat="server" PageSize="5" >
            <Fields>
              <asp:NextPreviousPagerField 
                ButtonType="Button"
                ShowFirstPageButton="True" 
                ShowLastPageButton="True" />
            </Fields>
          </asp:DataPager>
        </LayoutTemplate>
        <ItemTemplate>
          <asp:Image ID="ProductImage" runat="server"
            ImageUrl='<%# "~/images/thumbnails/" & Eval("ThumbnailPhotoFileName") %>' />            
          <div class="plainBox" runat="server">
            <asp:HyperLink ID="ProductLink" runat="server" Text='<%# Eval("Name") %>' 
              NavigateUrl='<%# "ProductDetails.aspx?productID=" & Eval("ProductID") %>' />
            <br /><br />
            <b>Price:</b> 
            <asp:Label ID="PriceLabel" runat="server" Text='<%# Eval("ListPrice", "{0:c}")%>' /> <br />
          </div>
          <br />
        </ItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects      -->
      <!-- to the AdventureWorks sample database. Use an ASP.NET    -->
      <!-- expression to retrieve the connection string value       -->
      <!-- from the Web.config file.                                -->
      <asp:SqlDataSource ID="ProductsDataSource" runat="server" 
        ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>"                        
        SelectCommand="SELECT P.ProductID, P.Name, P.Color, P.ListPrice, 
          PF.ThumbnailPhotoFileName, P.Size
          FROM Production.Product AS P 
          INNER JOIN Production.ProductProductPhoto AS PPF ON P.ProductID = PPF.ProductID 
          INNER JOIN Production.ProductPhoto AS PF ON PPF.ProductPhotoID = PF.ProductPhotoID
          WHERE P.Color = @Color" >
        <SelectParameters>
          <asp:ControlParameter ControlID="ColorList" Name="Color" 
            PropertyName="SelectedValue" />
        </SelectParameters>
      </asp:SqlDataSource>

      <asp:SqlDataSource ID="ColorDataSource" runat="server" 
        ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>" 
        SelectCommand="SELECT DISTINCT Color FROM Production.Product">
      </asp:SqlDataSource>

    </form>
  </body>
</html>
C#
<%@ Page language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Flow Layout Example</title>
    <style type="text/css">
      .plainBox {
          font-family: Verdana, Arial, sans-serif;
          font-size: 11px;
          background: #ffffff;
          border:1px solid #336666;
          }
    </style>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Flow Layout Example</h3>

      Select the color:
      <asp:DropDownList ID="ColorList" runat="server" 
        AutoPostBack="True" 
        DataSourceID="ColorDataSource" 
        DataTextField="Color" 
        DataValueField="Color">
      </asp:DropDownList><br /><br />

      <asp:ListView runat="server" ID="ProductListView"
        DataSourceID="ProductsDataSource"
        DataKeyNames="ProductID">
        <LayoutTemplate>
          <div runat="server" id="lstProducts">
            <div runat="server" id="itemPlaceholder" />
          </div>
          <asp:DataPager runat="server" PageSize="5" >
            <Fields>
              <asp:NextPreviousPagerField 
                ButtonType="Button"
                ShowFirstPageButton="True" 
                ShowLastPageButton="True" />
            </Fields>
          </asp:DataPager>
        </LayoutTemplate>
        <ItemTemplate>
          <asp:Image ID="ProductImage" runat="server"
            ImageUrl='<%# "~/images/thumbnails/" + Eval("ThumbnailPhotoFileName") %>' />            
          <div class="plainBox" runat="server">
            <asp:HyperLink ID="ProductLink" runat="server" Text='<%# Eval("Name") %>' 
              NavigateUrl='<%# "ProductDetails.aspx?productID=" + Eval("ProductID") %>' />
            <br /><br />
            <b>Price:</b> 
            <asp:Label ID="PriceLabel" runat="server" Text='<%# Eval("ListPrice", "{0:c}")%>' /> <br />
          </div>
          <br />
        </ItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects      -->
      <!-- to the AdventureWorks sample database. Use an ASP.NET    -->
      <!-- expression to retrieve the connection string value       -->
      <!-- from the Web.config file.                                -->
      <asp:SqlDataSource ID="ProductsDataSource" runat="server" 
        ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>"                        
        SelectCommand="SELECT P.ProductID, P.Name, P.Color, P.ListPrice, 
          PF.ThumbnailPhotoFileName, P.Size
          FROM Production.Product AS P 
          INNER JOIN Production.ProductProductPhoto AS PPF ON P.ProductID = PPF.ProductID 
          INNER JOIN Production.ProductPhoto AS PF ON PPF.ProductPhotoID = PF.ProductPhotoID
          WHERE P.Color = @Color" >
        <SelectParameters>
          <asp:ControlParameter ControlID="ColorList" Name="Color" 
            PropertyName="SelectedValue" />
        </SelectParameters>
      </asp:SqlDataSource>

      <asp:SqlDataSource ID="ColorDataSource" runat="server" 
        ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>" 
        SelectCommand="SELECT DISTINCT Color FROM Production.Product">
      </asp:SqlDataSource>

    </form>
  </body>
</html>

The following example shows how to use the ListView control to insert, delete, and update records.

Security noteSecurity Note

This example has a text box that accepts user input, which is a potential security threat. By default, ASP.NET Web pages validate that user input does not include script or HTML elements. For more information, see Script Exploits Overview.

Visual Basic
<%@ Page language="VB" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Example</title>
    <style type="text/css">
        .EditItem { background-color:#8FBC8F;}
        .SelectedItem {    background-color:#9ACD32; }
        .InsertItem { background-color:#FFFACD;}
    </style>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Example</h3>

      <h5>Departments</h5>

      <asp:ListView ID="DepartmentsListView" 
        DataSourceID="DepartmentsDataSource" 
        DataKeyNames="DepartmentID"
        ConvertEmptyStringToNull="true"
        InsertItemPosition="LastItem"
        runat="server">
        <LayoutTemplate>
          <table cellpadding="2" runat="server" id="tblDepartments" width="640px" cellspacing="0">
            <tr runat="server" id="itemPlaceholder" />
          </table>
        </LayoutTemplate>
        <ItemTemplate>
          <tr runat="server">
            <td>
              <asp:Button ID="SelectButton" runat="server" Text="Select" CommandName="Select" />
              <asp:Button ID="EditButton" runat="server" Text="Edit" CommandName="Edit" />
            </td>
            <td>
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%#Eval("Name") %>' />
            </td>
            <td>
              <asp:Label ID="GroupNameLabel" runat="server" Text='<%#Eval("GroupName") %>' />
            </td>
          </tr>
        </ItemTemplate>
        <SelectedItemTemplate>
          <tr class="SelectedItem" runat="server">
            <td>
              <asp:Button ID="DeleteButton" runat="server" Text="Delete" CommandName="Delete" />
              <asp:Button ID="EditButton" runat="server" Text="Edit" CommandName="Edit" />
            </td>
            <td>
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%#Eval("Name") %>' />
            </td>
            <td>
              <asp:Label ID="GroupNameLabel" runat="server" Text='<%#Eval("GroupName") %>' />
            </td>
          </tr>
        </SelectedItemTemplate>
        <EditItemTemplate>
          <tr class="EditItem">
            <td>
              <asp:Button ID="UpdateButton" runat="server" CommandName="Update" Text="Update" />
              <asp:Button ID="CancelButton" runat="server" CommandName="Cancel" Text="Cancel" />
            </td>
            <td>
              <b>ID</b><br />
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label runat="server" ID="NameLabel" AssociatedControlID="NameTextBox" 
                Text="Name" Font-Bold="true"/><br />
              <asp:TextBox ID="NameTextBox" runat="server" Text='<%#Bind("Name") %>' />
            </td>
            <td>
              <asp:Label runat="server" ID="GroupNameLabel" AssociatedControlID="GroupNameTextBox" 
                Text="Group Name" Font-Bold="true" /><br />
              <asp:TextBox ID="GroupNameTextBox" runat="server" 
                Width="200px"
                Text='<%#Bind("GroupName") %>' />
              <br />
            </td>
          </tr>
        </EditItemTemplate>
        <InsertItemTemplate>
          <tr class="InsertItem">
            <td colspan="2">
              <asp:Button ID="InsertButton" runat="server" CommandName="Insert" Text="Insert" />
              <asp:Button ID="CancelButton" runat="server" CommandName="Cancel" Text="Cancel" />
            </td>
            <td>
              <asp:Label runat="server" ID="NameLabel" AssociatedControlID="NameTextBox" 
                Text="Name" Font-Bold="true"/><br />
              <asp:TextBox ID="NameTextBox" runat="server" Text='<%#Bind("Name") %>' /><br />
            </td>
            <td>
              <asp:Label runat="server" ID="GroupNameLabel" AssociatedControlID="GroupNameTextBox" 
                Text="Group Name" Font-Bold="true" /><br />                
              <asp:TextBox ID="GroupNameTextBox" runat="server" Text='<%#Bind("GroupName") %>' />
            </td>
          </tr>
        </InsertItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects      -->
      <!-- to the AdventureWorks sample database. Use an ASP.NET    -->
      <!-- expression to retrieve the connection string value       -->
      <!-- from the Web.config file.                                -->            
      <asp:SqlDataSource ID="DepartmentsDataSource" runat="server" 
            ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>"
            SelectCommand="SELECT DepartmentID, Name, GroupName FROM HumanResources.Department"
            UpdateCommand="UPDATE HumanResources.Department 
                SET Name = @Name, GroupName = @GroupName WHERE (DepartmentID = @DepartmentID)"            
            DeleteCommand="DELETE FROM HumanResources.Department 
                WHERE (DepartmentID = @DepartmentID)" 
            InsertCommand="INSERT INTO HumanResources.Department(Name, GroupName) 
                VALUES (@Name, @GroupName)">
      </asp:SqlDataSource>

    </form>
  </body>
</html>
C#
<%@ Page language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Example</title>
    <style type="text/css">
        .EditItem { background-color:#8FBC8F;}
        .SelectedItem {    background-color:#9ACD32; }
        .InsertItem { background-color:#FFFACD;}
    </style>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Example</h3>

      <h5>Departments</h5>

      <asp:ListView ID="DepartmentsListView" 
        DataSourceID="DepartmentsDataSource" 
        DataKeyNames="DepartmentID"
        ConvertEmptyStringToNull="true"
        InsertItemPosition="LastItem"
        runat="server">
        <LayoutTemplate>
          <table cellpadding="2" runat="server" id="tblDepartments" width="640px" cellspacing="0">
            <tr runat="server" id="itemPlaceholder" />
          </table>
        </LayoutTemplate>
        <ItemTemplate>
          <tr runat="server">
            <td>
              <asp:Button ID="SelectButton" runat="server" Text="Select" CommandName="Select" />
              <asp:Button ID="EditButton" runat="server" Text="Edit" CommandName="Edit" />
            </td>
            <td>
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%#Eval("Name") %>' />
            </td>
            <td>
              <asp:Label ID="GroupNameLabel" runat="server" Text='<%#Eval("GroupName") %>' />
            </td>
          </tr>
        </ItemTemplate>
        <SelectedItemTemplate>
          <tr class="SelectedItem" runat="server">
            <td>
              <asp:Button ID="DeleteButton" runat="server" Text="Delete" CommandName="Delete" />
              <asp:Button ID="EditButton" runat="server" Text="Edit" CommandName="Edit" />
            </td>
            <td>
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%#Eval("Name") %>' />
            </td>
            <td>
              <asp:Label ID="GroupNameLabel" runat="server" Text='<%#Eval("GroupName") %>' />
            </td>
          </tr>
        </SelectedItemTemplate>
        <EditItemTemplate>
          <tr class="EditItem">
            <td>
              <asp:Button ID="UpdateButton" runat="server" CommandName="Update" Text="Update" />
              <asp:Button ID="CancelButton" runat="server" CommandName="Cancel" Text="Cancel" />
            </td>
            <td>
              <b>ID</b><br />
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label runat="server" ID="NameLabel" AssociatedControlID="NameTextBox" 
                Text="Name" Font-Bold="true"/><br />
              <asp:TextBox ID="NameTextBox" runat="server" Text='<%#Bind("Name") %>' />
            </td>
            <td>
              <asp:Label runat="server" ID="GroupNameLabel" AssociatedControlID="GroupNameTextBox" 
                Text="Group Name" Font-Bold="true" /><br />
              <asp:TextBox ID="GroupNameTextBox" runat="server" 
                Width="200px"
                Text='<%#Bind("GroupName") %>' />
              <br />
            </td>
          </tr>
        </EditItemTemplate>
        <InsertItemTemplate>
          <tr class="InsertItem">
            <td colspan="2">
              <asp:Button ID="InsertButton" runat="server" CommandName="Insert" Text="Insert" />
              <asp:Button ID="CancelButton" runat="server" CommandName="Cancel" Text="Cancel" />
            </td>
            <td>
              <asp:Label runat="server" ID="NameLabel" AssociatedControlID="NameTextBox" 
                Text="Name" Font-Bold="true"/><br />
              <asp:TextBox ID="NameTextBox" runat="server" Text='<%#Bind("Name") %>' /><br />
            </td>
            <td>
              <asp:Label runat="server" ID="GroupNameLabel" AssociatedControlID="GroupNameTextBox" 
                Text="Group Name" Font-Bold="true" /><br />                
              <asp:TextBox ID="GroupNameTextBox" runat="server" Text='<%#Bind("GroupName") %>' />
            </td>
          </tr>
        </InsertItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects      -->
      <!-- to the AdventureWorks sample database. Use an ASP.NET    -->
      <!-- expression to retrieve the connection string value       -->
      <!-- from the Web.config file.                                -->            
      <asp:SqlDataSource ID="DepartmentsDataSource" runat="server" 
            ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>"
            SelectCommand="SELECT DepartmentID, Name, GroupName FROM HumanResources.Department"
            UpdateCommand="UPDATE HumanResources.Department 
                SET Name = @Name, GroupName = @GroupName WHERE (DepartmentID = @DepartmentID)"            
            DeleteCommand="DELETE FROM HumanResources.Department 
                WHERE (DepartmentID = @DepartmentID)" 
            InsertCommand="INSERT INTO HumanResources.Department(Name, GroupName) 
                VALUES (@Name, @GroupName)">
      </asp:SqlDataSource>

    </form>
  </body>
</html>

.NET Framework

Supported in: 4, 3.5

Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows Server 2008 (Server Core Role not supported), Windows Server 2008 R2 (Server Core Role not supported), Windows Server 2003 SP2

The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.
Any public static (Shared in Visual Basic) members of this type are thread safe. Any instance members are not guaranteed to be thread safe.
Bibliothèque de classes .NET Framework
ListView, classe

Affiche les valeurs d'une source de données à l'aide de modèles définis par l'utilisateur. Le contrôle ListView permet aux utilisateurs de sélectionner, trier, supprimer, modifier et insérer des enregistrements.

Espace de noms :  System.Web.UI.WebControls
Assembly :  System.Web.Extensions (dans System.Web.Extensions.dll)
Visual Basic
<ControlValuePropertyAttribute("SelectedValue")> _
<ToolboxBitmapAttribute(GetType(ListView), "ListView.bmp")> _
Public Class ListView _
    Inherits DataBoundControl _
    Implements INamingContainer, IPageableItemContainer, IPersistedSelector, IDataKeysControl,  _
    IDataBoundListControl, IDataBoundControl
C#
[ControlValuePropertyAttribute("SelectedValue")]
[ToolboxBitmapAttribute(typeof(ListView), "ListView.bmp")]
public class ListView : DataBoundControl, INamingContainer, 
    IPageableItemContainer, IPersistedSelector, IDataKeysControl, IDataBoundListControl, IDataBoundControl
VisualC++
[ControlValuePropertyAttribute(L"SelectedValue")]
[ToolboxBitmapAttribute(typeof(ListView), L"ListView.bmp")]
public ref class ListView : public DataBoundControl, 
    INamingContainer, IPageableItemContainer, IPersistedSelector, IDataKeysControl, IDataBoundListControl, 
    IDataBoundControl
F#
[<ControlValuePropertyAttribute("SelectedValue")>]
[<ToolboxBitmapAttribute(typeof(ListView), "ListView.bmp")>]
type ListView =  
    class
        inherit DataBoundControl
        interface INamingContainer
        interface IPageableItemContainer
        interface IPersistedSelector
        interface IDataKeysControl
        interface IDataBoundListControl
        interface IDataBoundControl
    end
ASP.NET
<asp:ListView />

Le type ListView expose les membres suivants.

  NomDescription
Méthode publiqueListViewInitialise une nouvelle instance de la classe ListView.
Début
  NomDescription
Propriété publiqueAccessKeySubstitue la propriété WebControl..::.AccessKey. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.AccessKey.)
Propriété protégéeAdapterObtient l'adaptateur spécifique au navigateur pour le contrôle. (Hérité de Control.)
Propriété publiqueAlternatingItemTemplateObtient ou définit le contenu personnalisé pour l'élément de données en alternance dans un contrôle ListView.
Propriété publiqueAppRelativeTemplateSourceDirectoryObtient ou définit le répertoire virtuel relatif à l'application de l'objet Page ou UserControl qui contient ce contrôle. (Hérité de Control.)
Propriété publiqueAttributesObtient la collection d'attributs arbitraires (pour le rendu uniquement) qui ne correspondent pas à des propriétés du contrôle. (Hérité de WebControl.)
Propriété publiqueBackColorSubstitue la propriété WebControl..::.BackColor. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.BackColor.)
Propriété publiqueBindingContainerInfrastructure. Obtient le contrôle qui contient la liaison de données de ce contrôle. (Hérité de Control.)
Propriété publiqueBorderColorSubstitue la propriété WebControl..::.BorderColor. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.BorderColor.)
Propriété publiqueBorderStyleSubstitue la propriété WebControl..::.BorderStyle. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.BorderStyle.)
Propriété publiqueBorderWidthSubstitue la propriété WebControl..::.BorderWidth. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.BorderWidth.)
Propriété protégéeChildControlsCreatedObtient une valeur qui indique si des contrôles enfants du contrôle serveur ont été créés. (Hérité de Control.)
Propriété publiqueClientIDObtient l'ID de contrôle pour le balisage HTML généré par ASP.NET. (Hérité de Control.)
Propriété publiqueClientIDModeObtient ou définit l'algorithme utilisé pour générer la valeur de la propriété ClientID. (Hérité de Control.)
Propriété publiqueClientIDRowSuffixObtient ou définit le nom du champ de données dont la valeur est utilisée pour identifier de façon unique chaque ligne de données d'un contrôle ListView lorsque la propriété ClientIDMode a la valeur Predictable.
Propriété publiqueClientIDRowSuffixDataKeysInfrastructure. Obtient les valeurs de données utilisées pour identifier de façon unique chaque instance d'un contrôle lié aux données lorsqu'ASP.NET génère la valeur ClientID.
Propriété protégéeClientIDSeparatorObtient une valeur de caractère représentant le caractère de séparation utilisé dans la propriété ClientID. (Hérité de Control.)
Propriété protégéeContextObtient l'objet HttpContext associé au contrôle serveur pour la demande Web en cours. (Hérité de Control.)
Propriété publiqueControlsObtient un objet ControlCollection qui représente les contrôles enfant du contrôle ListView. (Substitue Control..::.Controls.)
Propriété publiqueControlStyleObtient le style d'un contrôle serveur Web. Cette propriété est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Propriété publiqueControlStyleCreatedObtient une valeur indiquant si un objet Style a été créé pour la propriété ControlStyle. Cette propriété est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Propriété publiqueConvertEmptyStringToNullObtient ou définit une valeur qui indique si les chaînes vides ("") sont converties automatiquement en valeurs null lorsque le champ de données est mis à jour dans la source de données.
Propriété publiqueCssClassSubstitue la propriété WebControl..::.CssClass. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.CssClass.)
Propriété publiqueDataItemContainerObtient une référence au conteneur d'attribution de noms si celui-ci implémente IDataItemContainer. (Hérité de Control.)
Propriété publiqueDataKeyNamesObtient ou définit un tableau qui contient les noms des champs clés primaires pour les éléments affichés dans un contrôle ListView.
Propriété publiqueDataKeysObtient une collection d'objets DataKey qui représentent la valeur de clé de données pour chaque élément dans un contrôle ListView.
Propriété publiqueDataKeysContainerObtient une référence au conteneur d'attribution de noms si celui-ci implémente IDataKeysControl. (Hérité de Control.)
Propriété publiqueDataMemberObtient ou définit le nom de la liste des données auxquelles le contrôle lié aux données se lie, dans les cas où la source de données contient plusieurs listes distinctes d'éléments de données. (Hérité de DataBoundControl.)
Propriété publiqueDataSourceObtient ou définit l'objet duquel le contrôle lié aux données récupère sa liste d'éléments de données. (Hérité de BaseDataBoundControl.)
Propriété publiqueDataSourceIDObtient ou définit l'ID du contrôle duquel le contrôle lié aux données récupère sa liste d'éléments de données. (Hérité de DataBoundControl.)
Propriété publiqueDataSourceObjectObtient un objet qui implémente l'interface IDataSource, qui fournit l'accès au contenu des données de l'objet. (Hérité de DataBoundControl.)
Propriété protégéeDesignModeObtient une valeur indiquant si un contrôle est utilisé sur une aire de conception. (Hérité de Control.)
Propriété publiqueEditIndexObtient ou définit l'index de l'élément en cours de modification.
Propriété publiqueEditItemObtient l'élément qui est en mode modification dans un contrôle ListView.
Propriété publiqueEditItemTemplateObtient ou définit le contenu personnalisé de l'élément en mode Édition.
Propriété publiqueEmptyDataTemplateObtient ou définit le contenu défini par l'utilisateur pour le modèle vide rendu lorsqu'un contrôle ListView est lié à une source de données qui ne contient pas d'enregistrements.
Propriété publiqueEmptyItemTemplateObtient ou définit le contenu défini par l'utilisateur pour l'élément vide restitué dans un contrôle ListView lorsqu'il n'y a plus d'éléments de données à afficher dans la dernière ligne de la page de données actuelle.
Propriété publiqueEnabledObtient ou définit une valeur indiquant si le contrôle serveur Web est activé. (Hérité de WebControl.)
Propriété publiqueEnableModelValidationObtient ou définit une valeur qui indique si un contrôle de validateur doit gérer les exceptions susceptibles de se produire lors des opérations d'insertion ou de mise à jour.
Propriété publiqueEnablePersistedSelectionObtient ou définit une valeur qui indique si la sélection de ligne persiste lorsqu'un utilisateur parcourt des données dans un contrôle lié aux données.
Propriété publiqueEnableThemingObtient ou définit une valeur indiquant si les thèmes s'appliquent à ce contrôle. (Hérité de WebControl.)
Propriété publiqueEnableViewStateObtient ou définit une valeur indiquant si le contrôle serveur rend persistant son état d'affichage, ainsi que celui de tous les contrôles enfants qu'il contient, sur le client à l'origine de la demande. (Hérité de Control.)
Propriété protégéeEventsObtient la liste des délégués de gestionnaires d'événements pour le contrôle. Cette propriété est en lecture seule. (Hérité de Control.)
Propriété publiqueFontSubstitue la propriété WebControl..::.Font. Cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.Font.)
Propriété publiqueForeColorSubstitue la propriété WebControl..::.ForeColor. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.ForeColor.)
Propriété publiqueGroupItemCountObtient ou définit le nombre d'éléments à afficher par groupe dans un contrôle ListView.
Propriété publiqueGroupPlaceholderIDObtient ou définit l'ID pour l'espace réservé de groupe dans un contrôle ListView.
Propriété publiqueGroupSeparatorTemplateObtient ou définit le contenu défini par l'utilisateur pour le séparateur de groupes dans un contrôle ListView.
Propriété publiqueGroupTemplateObtient ou définit le contenu défini par l'utilisateur pour le conteneur de groupe dans un contrôle ListView.
Propriété publiqueHasAttributesObtient une valeur indiquant si le contrôle a des attributs définis. (Hérité de WebControl.)
Propriété protégéeHasChildViewStateObtient une valeur indiquant si les contrôles enfants du contrôle serveur en cours possèdent des paramètres d'état d'affichage enregistrés. (Hérité de Control.)
Propriété publiqueHeightSubstitue la propriété WebControl..::.Height. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.Height.)
Propriété publiqueIDObtient ou définit l'ID programmatique assigné au contrôle serveur. (Hérité de Control.)
Propriété protégéeIdSeparatorInfrastructure. Obtient le caractère utilisé pour séparer des identificateurs de contrôle. (Hérité de Control.)
Propriété protégéeInitializedObtient une valeur indiquant si le contrôle lié aux données a été initialisé. (Hérité de BaseDataBoundControl.)
Propriété publiqueInsertItemObtient l'élément d'insertion dans un contrôle ListView.
Propriété publiqueInsertItemPositionObtient ou définit l'emplacement du modèle InsertItemTemplate lorsqu'il est restitué dans le cadre du contrôle ListView.
Propriété publiqueInsertItemTemplateObtient ou définit le contenu personnalisé pour un élément d'insertion dans le contrôle ListView.
Propriété protégéeIsBoundUsingDataSourceIDObtient une valeur indiquant si la propriété DataSourceID est définie. (Hérité de BaseDataBoundControl.)
Propriété protégéeIsChildControlStateClearedObtient une valeur indiquant si les contrôles contenus dans ce contrôle utilisent l'état du contrôle. (Hérité de Control.)
Propriété protégéeIsEnabledObtient une valeur indiquant si le contrôle est activé. (Hérité de WebControl.)
Propriété protégéeIsTrackingViewStateObtient une valeur qui indique si le contrôle serveur enregistre les modifications apportées à son état d'affichage. (Hérité de Control.)
Propriété protégéeIsViewStateEnabledObtient une valeur indiquant si l'état d'affichage est activé pour ce contrôle. (Hérité de Control.)
Propriété publiqueItemPlaceholderIDObtient ou définit l'ID pour l'espace réservé d'élément dans un contrôle ListView.
Propriété publiqueItemsObtient une collection d'objets ListViewDataItem qui représentent les éléments de données de la page de données actuelle dans un contrôle ListView.
Propriété publiqueItemSeparatorTemplateObtient ou définit le contenu personnalisé pour le séparateur entre les éléments dans un contrôle ListView.
Propriété publiqueItemTemplateObtient ou définit le contenu personnalisé pour l'élément de données dans un contrôle ListView.
Propriété publiqueLayoutTemplateObtient ou définit le contenu personnalisé pour le conteneur racine dans un contrôle ListView.
Propriété protégéeLoadViewStateByIDObtient une valeur indiquant si le contrôle participe au chargement de son état d'affichage par ID et non par index. (Hérité de Control.)
Propriété protégéeMaximumRowsObtient le nombre d'éléments maximum à afficher sur une même page du contrôle ListView.
Propriété publiqueNamingContainerObtient une référence au conteneur d'attribution de noms du contrôle serveur, qui crée un espace de noms unique pour différencier les contrôles serveur dont la propriété Control..::.ID possède la même valeur. (Hérité de Control.)
Propriété publiquePageObtient une référence à l'instance de Page qui contient le contrôle serveur. (Hérité de Control.)
Propriété publiqueParentObtient une référence au contrôle parent du contrôle serveur dans la hiérarchie des contrôles de la page. (Hérité de Control.)
Propriété publiqueRenderingCompatibilityObtient une valeur qui spécifie la version ASP.NET avec laquelle le HTML restitué sera compatible. (Hérité de Control.)
Propriété protégéeRequiresDataBindingObtient ou définit une valeur indiquant si la méthode DataBind doit être appelée. (Hérité de BaseDataBoundControl.)
Propriété protégéeSelectArgumentsObtient un objet DataSourceSelectArguments que le contrôle lié aux données utilise lors de la récupération de données à partir d'un contrôle de source de données. (Hérité de DataBoundControl.)
Propriété publiqueSelectedDataKeyObtient la valeur de clés des données pour l'élément sélectionné dans un contrôle ListView.
Propriété publiqueSelectedIndexObtient ou définit l'index de l'élément sélectionné dans un contrôle ListView.
Propriété publiqueSelectedItemTemplateObtient ou définit le contenu personnalisé pour l'élément sélectionné dans un contrôle ListView.
Propriété publiqueSelectedPersistedDataKeyObtient ou définit la valeur de clé de données de l'élément persistant sélectionné dans un contrôle lié aux données.
Propriété publiqueSelectedValueObtient la valeur de clés des données de l'élément sélectionné dans un contrôle ListView.
Propriété publiqueSiteObtient des informations sur le conteneur qui héberge le contrôle en cours lorsqu'il est rendu sur une aire de conception. (Hérité de Control.)
Propriété publiqueSkinIDObtient ou définit l'apparence à appliquer au contrôle. (Hérité de WebControl.)
Propriété publiqueSortDirectionObtient le sens de tri du champ ou des champs en cours de tri.
Propriété publiqueSortExpressionObtient l'expression de tri associée au champ ou aux champs en cours de tri.
Propriété protégéeStartRowIndexObtient l'index du premier enregistrement affiché dans une page de données dans le contrôle ListView.
Propriété publiqueStyleObtient une collection d'attributs de texte qui sont rendus en tant qu'attribut de style sur la balise extérieure d'un contrôle serveur Web. (Hérité de WebControl.)
Propriété publiqueSupportsDisabledAttributeObtient une valeur qui indique si le contrôle doit affecter à l'attribut disabled de l'élément HTML rendu la valeur "disabled" lorsque la propriété IsEnabled du contrôle a la valeur false. (Hérité de BaseDataBoundControl.)
Propriété publiqueTabIndexSubstitue la propriété WebControl..::.TabIndex. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.TabIndex.)
Propriété protégéeTagKeyObtient la valeur HtmlTextWriterTag qui correspond au contrôle serveur Web. Cette propriété est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Propriété protégéeTagNameObtient le nom de la balise du contrôle. Cette propriété est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Propriété publiqueTemplateControlObtient ou définit une référence au modèle qui contient ce contrôle. (Hérité de Control.)
Propriété publiqueTemplateSourceDirectoryObtient le répertoire virtuel du Page ou du UserControl qui contient le contrôle serveur en cours. (Hérité de Control.)
Propriété publiqueToolTipSubstitue la propriété WebControl..::.ToolTip. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.ToolTip.)
Propriété publiqueUniqueIDObtient l'identificateur unique qualifié sur le plan hiérarchique du contrôle serveur. (Hérité de Control.)
Propriété protégéeViewStateObtient un dictionnaire d'informations d'état qui vous permet d'enregistrer et de restaurer l'état d'affichage d'un contrôle serveur entre plusieurs demandes de la même page. (Hérité de Control.)
Propriété protégéeViewStateIgnoresCaseObtient une valeur qui indique si l'objet StateBag respecte la casse. (Hérité de Control.)
Propriété publiqueViewStateModeObtient ou définit le mode d'état d'affichage de ce contrôle. (Hérité de Control.)
Propriété publiqueVisibleObtient ou définit une valeur qui indique si un contrôle serveur est rendu sous la forme d'une interface utilisateur sur la page. (Hérité de Control.)
Propriété publiqueWidthSubstitue la propriété WebControl..::.Width. La définition de cette propriété n'est pas prise en charge par le contrôle ListView. (Substitue WebControl..::.Width.)
Début
  NomDescription
Méthode protégéeAddAttributesToRenderAjoute des attributs et des styles HTML qui doivent être rendus au HtmlTextWriterTag spécifié. Cette méthode est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Méthode protégéeAddControlToContainerAjoute le contrôle spécifié au conteneur spécifié.
Méthode protégéeAddedControlAppelée après l'ajout d'un contrôle enfant à la collection Controls de l'objet Control. (Hérité de Control.)
Méthode protégéeAddParsedSubObjectAvertit le contrôle serveur qu'un élément XML ou HTML a été analysé et l'ajoute à l'objet ControlCollection du contrôle serveur. (Hérité de Control.)
Méthode publiqueApplyStyleCopie tous les éléments non vides du style spécifié vers le contrôle Web, en remplaçant les éléments de style existants du contrôle. Cette méthode est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Méthode publiqueApplyStyleSheetSkinApplique les propriétés de style définies dans la feuille de style de la page au contrôle. (Hérité de Control.)
Méthode protégéeBuildProfileTreeInfrastructure. Collecte des informations sur le contrôle serveur et les livre à la propriété Trace à afficher lorsque le traçage est activé pour la page. (Hérité de Control.)
Méthode protégéeClearCachedClientIDInfrastructure. Affecte à la valeur ClientID mise en cache la valeur nullNothingnullptrune référence null (Nothing en Visual Basic). (Hérité de Control.)
Méthode protégéeClearChildControlStateSupprime les informations sur l'état du contrôle des contrôles enfants du contrôle serveur. (Hérité de Control.)
Méthode protégéeClearChildStateSupprime les informations sur l'état d'affichage et sur l'état du contrôle de tous les contrôles enfants du contrôle serveur. (Hérité de Control.)
Méthode protégéeClearChildViewStateSupprime les informations d'état d'affichage de tous les contrôles enfants du contrôle serveur. (Hérité de Control.)
Méthode protégéeClearEffectiveClientIDModeInfrastructure. Affecte la valeur Inherit à la propriété ClientIDMode de l'instance de contrôle actuelle et de tous contrôles enfants. (Hérité de Control.)
Méthode protégéeConfirmInitStateDéfinit l'état initialisé du contrôle lié aux données. (Hérité de BaseDataBoundControl.)
Méthode publiqueCopyBaseAttributesCopie les propriétés non encapsulées par l'objet Style du contrôle serveur Web spécifié vers le contrôle serveur Web à partir duquel cette méthode est appelée. Cette méthode est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Méthode protégéeCreateChildControls()()()Crée la hiérarchie des contrôles utilisée pour restituer le contrôle ListView, basé sur les valeurs qui sont stockées dans l'état d'affichage. (Substitue Control..::.CreateChildControls()()().)
Méthode protégéeCreateChildControls(IEnumerable, Boolean)Crée la hiérarchie des contrôles qui est utilisée pour restituer le contrôle ListView à l'aide de la source de données spécifiée.
Méthode protégéeCreateControlCollectionCrée un nouvel objet ControlCollection pour contenir les contrôles enfants (littéraux et serveur) du contrôle serveur. (Hérité de Control.)
Méthode protégéeCreateControlStyleCrée le style par défaut du contrôle. (Substitue WebControl..::.CreateControlStyle()()().)
Méthode protégéeCreateDataItemCrée un élément de données dans le contrôle ListView.
Méthode protégéeCreateDataSourceSelectArgumentsCrée l'objet DataSourceSelectArguments qui contient les arguments passés à la source de données. (Substitue DataBoundControl..::.CreateDataSourceSelectArguments()()().)
Méthode protégéeCreateEmptyDataItemCrée le modèle EmptyDataTemplate dans le contrôle ListView.
Méthode protégéeCreateEmptyItemCrée un élément vide dans le contrôle ListView.
Méthode protégéeCreateInsertItemCrée un élément d'insertion dans le contrôle ListView.
Méthode protégéeCreateItemCrée un objet ListViewItem avec le type spécifié.
Méthode protégéeCreateItemsInGroupsCrée la hiérarchie des contrôles ListView dans des groupes.
Méthode protégéeCreateItemsWithoutGroupsCrée la hiérarchie des contrôles ListView sans groupes.
Méthode protégéeCreateLayoutTemplateCrée le conteneur racine dans le contrôle ListView.
Méthode protégéeCreateSuffixArrayListInfrastructure. Crée un tableau de suffixes pour qu'ASP.NET l'utilise lorsqu'il génère la valeur ClientID.
Méthode publiqueDataBind()()()Lie une source de données au contrôle serveur appelé et à tous ses contrôles enfants. (Hérité de BaseDataBoundControl.)
Méthode protégéeDataBind(Boolean)Lie une source de données au contrôle serveur appelé et tous ses contrôles enfants avec une option pour déclencher l'événement DataBinding. (Hérité de Control.)
Méthode protégéeDataBindChildrenLie une source de données aux contrôles enfants du contrôle serveur. (Hérité de Control.)
Méthode publiqueDeleteItemSupprime l'enregistrement à l'index spécifié de la source de données.
Méthode publiqueDisposePermet à un contrôle serveur d'effectuer le nettoyage final avant qu'il soit libéré de la mémoire. (Hérité de Control.)
Méthode protégéeEnsureChildControlsDétermine si le contrôle serveur contient des contrôles enfants. S'il ne contient pas de contrôles enfants, il en crée. (Hérité de Control.)
Méthode protégéeEnsureDataBoundAppelle la méthode DataBind si la propriété DataSourceID est définie et que le contrôle lié aux données est marqué pour demander à être lié. (Hérité de BaseDataBoundControl.)
Méthode protégéeEnsureIDCrée un identificateur pour les contrôles auxquels aucun identificateur n'est assigné. (Hérité de Control.)
Méthode protégéeEnsureLayoutTemplateGarantit que le contenu LayoutTemplate est créé correctement dans le contrôle ListView.
Méthode publiqueEquals(Object)Détermine si l'Object spécifié est égal à l'Object en cours. (Hérité de Object.)
Méthode publiqueExtractItemValuesRécupère les valeurs de chaque champ déclarées dans l'élément spécifié et les stocke dans l'objet IOrderedDictionary spécifié.
Méthode protégéeFinalizeAutorise un objet à tenter de libérer des ressources et d'exécuter d'autres opérations de netto***ge avant qu'il ne soit récupéré par l'opération garbage collection. (Hérité de Object.)
Méthode publiqueFindControl(String)Recherche un contrôle serveur possédant le paramètre id spécifié dans le conteneur d'attribution de noms actuel. (Hérité de Control.)
Méthode protégéeFindControl(String, Int32)Infrastructure. Recherche le conteneur d'attribution de noms actuel d'un contrôle serveur avec l'id spécifié et un entier, spécifié dans le paramètre pathOffset, qui facilite la recherche. Vous ne devez pas substituer cette version de la méthode FindControl. (Hérité de Control.)
Méthode protégéeFindPlaceholderRecherche le conteneur spécifié pour un contrôle qui possède l'identificateur spécifié.
Méthode publiqueFocusAffecte le focus d'entrée à un contrôle. (Hérité de Control.)
Méthode protégéeGetDataRécupère un objet DataSourceView que le contrôle lié aux données utilise pour exécuter des opérations de données. (Hérité de DataBoundControl.)
Méthode protégéeGetDataSourceRécupère l'interface IDataSource à laquelle le contrôle lié aux données est associé, le cas échéant. (Hérité de DataBoundControl.)
Méthode protégéeGetDesignModeStateInfrastructure. Obtient les données au moment du design pour un contrôle. (Hérité de Control.)
Méthode publiqueGetHashCodeSert de fonction de hachage pour un type particulier. (Hérité de Object.)
Méthode publiqueGetRouteUrl(Object)Obtient l'URL qui correspond à un jeu de paramètres d'itinéraire. (Hérité de Control.)
Méthode publiqueGetRouteUrl(RouteValueDictionary)Obtient l'URL qui correspond à un jeu de paramètres d'itinéraire. (Hérité de Control.)
Méthode publiqueGetRouteUrl(String, Object)Obtient l'URL qui correspond à un jeu de paramètres d'itinéraire et à un nom d'itinéraire. (Hérité de Control.)
Méthode publiqueGetRouteUrl(String, RouteValueDictionary)Obtient l'URL qui correspond à un jeu de paramètres d'itinéraire et à un nom d'itinéraire. (Hérité de Control.)
Méthode publiqueGetTypeObtient le Type de l'instance actuelle. (Hérité de Object.)
Méthode publiqueGetUniqueIDRelativeToRetourne la partie préfixée de la propriété UniqueID du contrôle spécifié. (Hérité de Control.)
Méthode publiqueHasControlsDétermine si le contrôle serveur contient des contrôles enfants. (Hérité de Control.)
Méthode protégéeHasEventsRetourne une valeur indiquant si des événements sont inscrits pour le contrôle ou des contrôles enfants. (Hérité de Control.)
Méthode publiqueInsertNewItemInsère l'enregistrement actif dans la source de données.
Méthode protégéeInstantiateEmptyDataTemplateRemplit l'objet Control spécifié en utilisant les contrôles enfants contenus dans le modèle EmptyDataTemplate.
Méthode protégéeInstantiateEmptyItemTemplateRemplit l'objet Control spécifié en utilisant les contrôles enfants contenus dans le modèle EmptyItemTemplate.
Méthode protégéeInstantiateGroupSeparatorTemplateRemplit l'objet Control spécifié en utilisant les contrôles enfants contenus dans le modèle GroupSeparatorTemplate.
Méthode protégéeInstantiateGroupTemplateRemplit l'objet Control spécifié en utilisant les contrôles enfants contenus dans le modèle GroupTemplate.
Méthode protégéeInstantiateInsertItemTemplateRemplit l'objet Control spécifié en utilisant les contrôles enfants contenus dans le modèle InsertItemTemplate.
Méthode protégéeInstantiateItemSeparatorTemplateRemplit l'objet Control spécifié en utilisant les contrôles enfants contenus dans le modèle ItemSeparatorTemplate.
Méthode protégéeInstantiateItemTemplateRemplit l'objet Control spécifié en utilisant des contrôles enfants de l'un des modèles de contrôle ListView.
Méthode protégéeIsLiteralContentInfrastructure. Détermine si le contrôle serveur ne détient qu'un contenu littéral. (Hérité de Control.)
Méthode protégéeLoadControlStateCharge l'état des propriétés dans le contrôle ListView à faire persister, même lorsque la propriété EnableViewState a la valeur false. (Substitue Control..::.LoadControlState(Object).)
Méthode protégéeLoadViewStateCharge l'état d'affichage précédemment enregistré du contrôle ListView. (Substitue WebControl..::.LoadViewState(Object).)
Méthode protégéeMapPathSecureRécupère le chemin d'accès physique auquel un chemin d'accès virtuel, absolu ou relatif, correspond. (Hérité de Control.)
Méthode protégéeMarkAsDataBoundDéfinit l'état du contrôle dans l'état d'affichage comme lié avec succès aux données. (Hérité de DataBoundControl.)
Méthode protégéeMemberwiseCloneCrée une copie superficielle de l'objet Object actif. (Hérité de Object.)
Méthode publiqueMergeStyleCopie tous les éléments non vides du style spécifié vers le contrôle Web, mais ne remplace aucun élément de style existant du contrôle. Cette méthode est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Méthode protégéeOnBubbleEventDétermine si un événement pour le contrôle ListView doit être géré. (Substitue Control..::.OnBubbleEvent(Object, EventArgs).)
Méthode protégéeOnDataBindingDéclenche l'événement DataBinding. (Hérité de Control.)
Méthode protégéeOnDataBoundDéclenche l'événement DataBound. (Hérité de BaseDataBoundControl.)
Méthode protégéeOnDataPropertyChangedRelie le contrôle lié aux données à ses données après la modification d'une des propriétés de l'identification de la source de données de base. (Hérité de DataBoundControl.)
Méthode protégéeOnDataSourceViewChangedDéclenche l'événement DataSourceViewChanged. (Hérité de DataBoundControl.)
Méthode protégéeOnInitDéclenche l'événement Init. (Substitue BaseDataBoundControl..::.OnInit(EventArgs).)
Méthode protégéeOnItemCancelingDéclenche l'événement ItemCanceling.
Méthode protégéeOnItemCommandDéclenche l'événement ItemCommand.
Méthode protégéeOnItemCreatedDéclenche l'événement ItemCreated.
Méthode protégéeOnItemDataBoundDéclenche l'événement ItemDataBound.
Méthode protégéeOnItemDeletedDéclenche l'événement ItemDeleted.
Méthode protégéeOnItemDeletingDéclenche l'événement ItemDeleting.
Méthode protégéeOnItemEditingDéclenche l'événement ItemEditing.
Méthode protégéeOnItemInsertedDéclenche l'événement ItemInserted.
Méthode protégéeOnItemInsertingDéclenche l'événement ItemInserting.
Méthode protégéeOnItemUpdatedDéclenche l'événement ItemUpdated.
Méthode protégéeOnItemUpdatingDéclenche l'événement ItemUpdating.
Méthode protégéeOnLayoutCreatedDéclenche l'événement LayoutCreated.
Méthode protégéeOnLoadGère l'événement Control..::.Load. (Hérité de DataBoundControl.)
Méthode protégéeOnPagePreLoadDéfinit l'état initialisé du contrôle lié aux données avant que le contrôle ne soit chargé. (Hérité de DataBoundControl.)
Méthode protégéeOnPagePropertiesChangedDéclenche l'événement PagePropertiesChanged.
Méthode protégéeOnPagePropertiesChangingDéclenche l'événement PagePropertiesChanging.
Méthode protégéeOnPreRenderGère l'événement PreRender. (Hérité de BaseDataBoundControl.)
Méthode protégéeOnSelectedIndexChangedDéclenche l'événement SelectedIndexChanged.
Méthode protégéeOnSelectedIndexChangingDéclenche l'événement SelectedIndexChanging.
Méthode protégéeOnSortedDéclenche l'événement Sorted.
Méthode protégéeOnSortingDéclenche l'événement Sorting.
Méthode protégéeOnTotalRowCountAvailableDéclenche l'événement IPageableItemContainer..::.TotalRowCountAvailable.
Méthode protégéeOnUnloadDéclenche l'événement Unload. (Hérité de Control.)
Méthode protégéeOpenFileObtient un Stream utilisé pour lire un fichier. (Hérité de Control.)
Méthode protégéePerformDataBindingLie la source de données spécifiée au contrôle ListView. (Substitue DataBoundControl..::.PerformDataBinding(IEnumerable).)
Méthode protégéePerformSelectRécupère les données de la source de données associée. (Substitue DataBoundControl..::.PerformSelect()()().)
Méthode protégéeRaiseBubbleEventAssigne les sources éventuelles de l'événement et ses informations au parent du contrôle. (Hérité de Control.)
Méthode protégéeRemovedControlAppelée après la suppression d'un contrôle enfant dans la collection Controls de l'objet Control. (Hérité de Control.)
Méthode protégéeRemoveItemsSupprime tous les contrôles enfants dans un élément ou un conteneur de groupe du contrôle ListView.
Méthode protégéeRenderGénère le rendu du contenu du contrôle serveur Web via le navigateur du client à l'aide de l'objet HtmlTextWriter spécifié. (Substitue WebControl..::.Render(HtmlTextWriter).)
Méthode publiqueRenderBeginTagGénère le rendu de la balise d'ouverture HTML du contrôle via le writer spécifié. Cette méthode est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Méthode protégéeRenderChildrenRenvoie le contenu des enfants d'un contrôle serveur dans un objet HtmlTextWriter fourni, qui écrit le contenu à rendre sur le client. (Hérité de Control.)
Méthode protégéeRenderContentsGénère le rendu du contenu du contrôle via le writer spécifié. Cette méthode est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Méthode publiqueRenderControl(HtmlTextWriter)Renvoie le contenu du contrôle serveur dans un objet HtmlTextWriter fourni et stocke des informations de traçage au sujet du contrôle si le traçage est activé. (Hérité de Control.)
Méthode protégéeRenderControl(HtmlTextWriter, ControlAdapter)Génère le contenu du contrôle serveur dans un objet HtmlTextWriter à l'aide d'un objet ControlAdapter fourni. (Hérité de Control.)
Méthode publiqueRenderEndTagGénère le rendu de la balise de fermeture HTML du contrôle via le writer spécifié. Cette méthode est principalement utilisée par des développeurs de contrôles. (Hérité de WebControl.)
Méthode protégéeResolveAdapterObtient l'adaptateur de contrôles responsable du rendu du contrôle spécifié. (Hérité de Control.)
Méthode publiqueResolveClientUrlObtient une URL qui peut être utilisée par le navigateur. (Hérité de Control.)
Méthode publiqueResolveUrlConvertit une URL en une URL que le client soit en mesure d'utiliser. (Hérité de Control.)
Méthode protégéeSaveControlStateEnregistre l'état des propriétés dans le contrôle ListView à faire persister, même lorsque la propriété EnableViewState a la valeur false. (Substitue Control..::.SaveControlState()()().)
Méthode protégéeSaveViewStateEnregistre l'état d'affichage actuel du contrôle ListView. (Substitue WebControl..::.SaveViewState()()().)
Méthode publiqueSelectItemSélectionne l'élément en mode édition dans un contrôle ListView.
Méthode protégéeSetDesignModeStateDéfinit les données au moment du design pour un contrôle. (Hérité de Control.)
Méthode publiqueSetEditItemDéfinit l'élément spécifié en mode édition dans un contrôle ListView.
Méthode protégéeSetPagePropertiesDéfinit les propriétés d'une page de données dans le contrôle ListView.
Méthode publiqueSetRenderMethodDelegateInfrastructure. Assigne un délégué de gestionnaires d'événements pour générer le rendu du contrôle serveur et de son contenu dans son contrôle parent. (Hérité de Control.)
Méthode publiqueSortTrie le contrôle ListView selon l'expression et le sens de tri spécifiés.
Méthode publiqueToStringRetourne une chaîne qui représente l'objet actuel. (Hérité de Object.)
Méthode protégéeTrackViewStateAmène le contrôle à suivre les modifications apportées à son état d'affichage afin qu'elles puissent être stockées dans la propriété ViewState de l'objet. (Hérité de WebControl.)
Méthode publiqueUpdateItemMet à jour l'enregistrement à l'index spécifié dans la source de données.
Méthode protégéeValidateDataSourceVérifie que l'objet auquel un contrôle lié aux données se lie est un objet avec qui il peut fonctionner. (Hérité de DataBoundControl.)
Début
  NomDescription
Événement publicDataBindingSe produit lorsque le contrôle serveur se lie à une source de données. (Hérité de Control.)
Événement publicDataBoundSe produit après la liaison du contrôle serveur à une source de données. (Hérité de BaseDataBoundControl.)
Événement publicDisposedSe produit lorsqu'un contrôle serveur est libéré de la mémoire, ce qui constitue la dernière étape du cycle de vie d'un contrôle serveur en cas de demande d'une page ASP.NET. (Hérité de Control.)
Événement publicInitSe produit lorsque le contrôle serveur est initialisé, ce qui constitue la première étape de son cycle de vie. (Hérité de Control.)
Événement publicItemCancelingSe produit lorsqu'une opération d'annulation est demandée, mais avant que le contrôle ListView n'annule l'opération d'insertion ou de modification.
Événement publicItemCommandSe produit lorsque l'on clique sur un bouton dans un contrôle ListView.
Événement publicItemCreatedSe produit lors de la création d'un élément dans un contrôle ListView.
Événement publicItemDataBoundSe produit lorsqu'un élément de données est lié à des données dans un contrôle ListView.
Événement publicItemDeletedSe produit lorsqu'une opération de Suppression est demandée, après que le contrôle ListView ait supprimé l'élément.
Événement publicItemDeletingSe produit lorsqu'une opération de Suppression est demandée, mais avant que le contrôle ListView ait supprimé l'élément.
Événement publicItemEditingSe produit lorsqu'une modification est demandée, mais avant que l'élément ListView soit mis en mode Édition.
Événement publicItemInsertedSe produit lorsqu'une opération d'insertion est demandée, après que le contrôle ListView a inséré l'élément dans la source de données.
Événement publicItemInsertingSe produit lorsqu'une opération d'insertion est demandée, mais avant que le contrôle ListView n'exécute l'insertion.
Événement publicItemUpdatedSe produit lorsqu'une opération de mise à jour est demandée, après que le contrôle ListView ait mis à jour l'élément.
Événement publicItemUpdatingSe produit lorsqu'une opération de mise à jour est demandée, mais avant que le contrôle ListView n'ait mis à jour l'élément.
Événement publicLayoutCreatedSe produit lorsque le modèle LayoutTemplate est créé dans un contrôle ListView.
Événement publicLoadSe produit lorsque le contrôle serveur est chargé dans l'objet Page. (Hérité de Control.)
Événement publicPagePropertiesChangedSe produit lorsque les propriétés de page sont modifiées, après que le contrôle ListView ait défini les nouvelles valeurs.
Événement publicPagePropertiesChangingSe produit lorsque les propriétés de pages sont modifiées, mais avant que le contrôle ListView n'ai défini les nouvelles valeurs.
Événement publicPreRenderSe produit après le chargement de l'objet Control mais avant le rendu. (Hérité de Control.)
Événement publicSelectedIndexChangedSe produit en cas de clic sur le bouton de sélection d'un élément, après que le contrôle ListView a géré l'opération de sélection.
Événement publicSelectedIndexChangingSe produit en cas de clic sur le bouton de sélection d'un élément, mais avant que le contrôle ListView ne gère l'opération de sélection.
Événement publicSortedSe produit lorsqu'une opération de tri est demandée, après que le contrôle ListView ait géré l'opération de tri.
Événement publicSortingSe produit lorsqu'une opération de tri est demandée, mais avant que le contrôle ListView ne gère l'opération de tri.
Événement publicUnloadSe produit lorsque le contrôle serveur est déchargé de la mémoire. (Hérité de Control.)
Début
  NomDescription
Méthode d'extension publiqueEnableDynamicData(Type)Surchargé. Active le comportement Dynamic Data pour le contrôle de données spécifié. (Défini par DataControlExtensions.)
Méthode d'extension publiqueEnableDynamicData(Type, Object)Surchargé. Active le comportement Dynamic Data pour le contrôle de données spécifié. (Défini par DataControlExtensions.)
Méthode d'extension publiqueEnableDynamicData(Type, IDictionary<(Of <(String, Object>)>))Surchargé. Active le comportement Dynamic Data pour le contrôle de données spécifié. (Défini par DataControlExtensions.)
Méthode d'extension publiqueEnablePersistedSelectionRend la sélection persistante dans les contrôles de données qui prennent en charge la sélection et la pagination. (Défini par DynamicDataExtensions.)
Méthode d'extension publiqueFindDataSourceControlRetourne la source de données associée au contrôle de données pour le contrôle spécifié. (Défini par DynamicDataExtensions.)
Méthode d'extension publiqueFindFieldTemplateRetourne le modèle de champ pour la colonne spécifiée dans le conteneur d'attribution de noms du contrôle spécifié. (Défini par DynamicDataExtensions.)
Méthode d'extension publiqueFindMetaTableRetourne l'objet Metatable pour le contrôle de données conteneur. (Défini par DynamicDataExtensions.)
Méthode d'extension publiqueGetDefaultValuesObtient la collection des valeurs par défaut pour le contrôle de données spécifié. (Défini par DynamicDataExtensions.)
Méthode d'extension publiqueGetMetaTableObtient les métadonnées de table pour le contrôle de données spécifié. (Défini par DynamicDataExtensions.)
Méthode d'extension publiqueSetMetaTable(MetaTable)Surchargé. Définit les métadonnées de table pour le contrôle de données spécifié. (Défini par DynamicDataExtensions.)
Méthode d'extension publiqueSetMetaTable(MetaTable, IDictionary<(Of <(String, Object>)>))Surchargé. Définit les métadonnées de table et le mappage des valeurs par défaut pour le contrôle de données spécifié. (Défini par DynamicDataExtensions.)
Méthode d'extension publiqueSetMetaTable(MetaTable, Object)Surchargé. Définit les métadonnées de table et le mappage des valeurs par défaut pour le contrôle de données spécifié. (Défini par DynamicDataExtensions.)
Méthode d'extension publiqueTryGetMetaTableDétermine si des métadonnées de table sont disponibles. (Défini par DynamicDataExtensions.)
Début
  NomDescription
Implémentation d'interface expliciteMéthode privéeIAttributeAccessor..::.GetAttributeInfrastructure. Obtient un attribut du contrôle Web avec le nom spécifié. (Hérité de WebControl.)
Implémentation d'interface expliciteMéthode privéeIAttributeAccessor..::.SetAttributeAffecte au nom et à la valeur spécifiés un attribut du contrôle Web. (Hérité de WebControl.)
Implémentation d'interface explicitePropriété privéeIControlBuilderAccessor..::.ControlBuilderPour obtenir une description de ce membre, consultez IControlBuilderAccessor..::.ControlBuilder. (Hérité de Control.)
Implémentation d'interface expliciteMéthode privéeIControlDesignerAccessor..::.GetDesignModeStatePour obtenir une description de ce membre, consultez IControlDesignerAccessor..::.GetDesignModeState. (Hérité de Control.)
Implémentation d'interface expliciteMéthode privéeIControlDesignerAccessor..::.SetDesignModeStatePour obtenir une description de ce membre, consultez IControlDesignerAccessor..::.SetDesignModeState. (Hérité de Control.)
Implémentation d'interface expliciteMéthode privéeIControlDesignerAccessor..::.SetOwnerControlInfrastructure. Pour obtenir une description de ce membre, consultez IControlDesignerAccessor..::.SetOwnerControl. (Hérité de Control.)
Implémentation d'interface explicitePropriété privéeIControlDesignerAccessor..::.UserDataPour obtenir une description de ce membre, consultez IControlDesignerAccessor..::.UserData. (Hérité de Control.)
Implémentation d'interface explicitePropriété privéeIDataBindingsAccessor..::.DataBindingsPour obtenir une description de ce membre, consultez IDataBindingsAccessor..::.DataBindings. (Hérité de Control.)
Implémentation d'interface explicitePropriété privéeIDataBindingsAccessor..::.HasDataBindingsPour obtenir une description de ce membre, consultez IDataBindingsAccessor..::.HasDataBindings. (Hérité de Control.)
Implémentation d'interface explicitePropriété privéeIDataBoundControl..::.DataKeyNamesObtient ou définit un tableau qui contient les noms des champs clé primaire des éléments qui sont affichés dans un contrôle lié aux données.
Implémentation d'interface explicitePropriété privéeIDataBoundControl..::.DataMemberObtient ou définit le nom de la liste de données à laquelle le contrôle lié aux données se lie lorsque la source de données contient plusieurs listes distinctes d'éléments de données.
Implémentation d'interface explicitePropriété privéeIDataBoundControl..::.DataSourceObtient ou définit l'objet duquel un contrôle lié aux données récupère sa liste d'éléments de données.
Implémentation d'interface explicitePropriété privéeIDataBoundControl..::.DataSourceIDObtient ou définit l'ID du contrôle de source de données duquel un contrôle lié aux données récupère sa liste d'éléments de données.
Implémentation d'interface explicitePropriété privéeIDataBoundControl..::.DataSourceObjectObtient un objet qui implémente l'interface IDataSource, qui fournit l'accès au contenu des données de l'objet.
Implémentation d'interface explicitePropriété privéeIDataBoundListControl..::.ClientIDRowSuffixObtient le nom du champ de données dont la valeur est utilisée pour identifier de façon unique chaque ligne de données d'un contrôle ListView lorsque la propriété ClientIDMode a la valeur Predictable.
Implémentation d'interface explicitePropriété privéeIDataBoundListControl..::.DataKeysObtient une collection de valeurs de clés de données qui représentent chaque ligne d'un contrôle lié aux données.
Implémentation d'interface explicitePropriété privéeIDataBoundListControl..::.EnablePersistedSelectionObtient ou définit la valeur qui spécifie si une ligne sélectionnée persiste lorsqu'un utilisateur parcourt des données dans un contrôle lié aux données.
Implémentation d'interface explicitePropriété privéeIDataBoundListControl..::.SelectedDataKeyObtient l'objet de clé de données qui contient la valeur de clé de données de la ligne sélectionnée dans un contrôle lié aux données.
Implémentation d'interface explicitePropriété privéeIDataBoundListControl..::.SelectedIndexObtient ou définit l'index de la ligne sélectionnée dans un contrôle lié aux données.
Implémentation d'interface explicitePropriété privéeIDataKeysControl..::.ClientIDRowSuffixDataKeysInfrastructure. Obtient une collection de valeurs de données utilisées pour identifier de façon unique chaque instance d'un contrôle lié aux données lorsqu'ASP.NET génère la valeur ClientID.
Implémentation d'interface explicitePropriété privéeIExpressionsAccessor..::.ExpressionsPour obtenir une description de ce membre, consultez IExpressionsAccessor..::.Expressions. (Hérité de Control.)
Implémentation d'interface explicitePropriété privéeIExpressionsAccessor..::.HasExpressionsPour obtenir une description de ce membre, consultez IExpressionsAccessor..::.HasExpressions. (Hérité de Control.)
Implémentation d'interface explicitePropriété privéeIPageableItemContainer..::.MaximumRowsInfrastructure. Pour obtenir une description de ce membre, consultez IPageableItemContainer..::.MaximumRows.
Implémentation d'interface expliciteMéthode privéeIPageableItemContainer..::.SetPagePropertiesInfrastructure. Pour obtenir une description de ce membre, consultez IPageableItemContainer..::.SetPageProperties.
Implémentation d'interface explicitePropriété privéeIPageableItemContainer..::.StartRowIndexInfrastructure. Pour obtenir une description de ce membre, consultez IPageableItemContainer..::.StartRowIndex.
Implémentation d'interface expliciteÉvénement privéIPageableItemContainer..::.TotalRowCountAvailableInfrastructure. Pour obtenir une description de ce membre, consultez IPageableItemContainer..::.TotalRowCountAvailable.
Implémentation d'interface expliciteMéthode privéeIParserAccessor..::.AddParsedSubObjectPour obtenir une description de ce membre, consultez IParserAccessor..::.AddParsedSubObject. (Hérité de Control.)
Implémentation d'interface explicitePropriété privéeIPersistedSelector..::.DataKeyObtient ou définit la valeur de clé de données de l'enregistrement sélectionné dans un contrôle lié aux données.
Début

Dans cette rubrique :

Introduction

Le contrôle ListView est utilisé pour afficher les valeurs à partir d'une source de données. Il ressemble au contrôle GridView, mais il affiche des données à l'aide de modèles définis par l'utilisateur au lieu de champs de ligne. La création de vos propres modèles offre davantage de souplesse pour contrôler la manière dont les données sont affichées.

Un projet Visual Studio (avec code source) est disponible pour accompagner cette rubrique : Download.

Le contrôle ListView prend en charge les fonctionnalités suivantes :

  • Prise en charge de la liaison à des contrôles de sources de données, tels que SqlDataSource, LinqDataSource et ObjectDataSource.

  • Apparence personnalisable grâce aux modèles et aux styles définis par l'utilisateur.

  • Fonctionnalités intégrées de tri.

  • Fonctionnalités intégrées de mise à jour et de suppression.

  • Fonctionnalités d'insertion intégrées.

  • Prise en charge de fonctionnalités de pagination à l'aide d'un contrôle DataPager.

  • Fonctionnalités intégrées de sélection d'élément.

  • Accès par programme au modèle objet ListView pour définir de manière dynamique la définition de propriétés, la gestion d'événements, etc.

  • Plusieurs champs clés.

Pour en savoir plus sur les autres contrôles liés aux données disponibles dans ASP.NET, consultez Vue d'ensemble des contrôles serveur Web liés aux données ASP.NET.

Modèles

Pour que le contrôle ListView affiche le contenu, vous devez créer des modèles pour différentes parties du contrôle. La propriété ItemTemplate est requise. Tous les autres modèles sont facultatifs. La propriété LayoutTemplate n'est pas requise.

Toutefois, vous devez créer un modèle pour le mode dans lequel le contrôle est configuré. Par exemple, un contrôle ListView qui prend en charge l'insertion d'enregistrements doit disposer d'un modèle InsertItemTemplate défini. Le tableau suivant énumère les modèles que vous pouvez créer pour le contrôle ListView.

Type de modèle

Description

LayoutTemplate

Le modèle racine qui définit un objet de conteneur, tel qu'un élément table, div ou span, qui contiendra le contenu défini dans le modèle ItemTemplate ou GroupTemplate. Il peut contenir également un objet DataPager.

ItemTemplate

Définit le contenu lié aux données à afficher pour des éléments individuels.

ItemSeparatorTemplate

Définit le contenu à restituer entre des éléments individuels.

GroupTemplate

Définit un objet de conteneur, telle qu'une ligne de tableau tr, div ou un élément span, qui contiendra le contenu défini dans les modèles ItemTemplate et EmptyItemTemplate. Le nombre d'éléments qui sont affichés dans un groupe est spécifié par la propriété GroupItemCount.

GroupSeparatorTemplate

Définit le contenu à restituer entre des groupes d'éléments.

EmptyItemTemplate

Définit le contenu à restituer pour un élément vide lorsqu'un modèle GroupTemplate est utilisé. Par exemple, si la propriété GroupItemCount a la valeur 5, et que le nombre total d'éléments retourné par la source de données est 8, le dernier groupe de données affiché par le contrôle ListView contiendra trois éléments comme spécifié par le modèle ItemTemplate, et deux éléments comme spécifié par le modèle EmptyItemTemplate.

EmptyDataTemplate

Définit le contenu à restituer si la source de données ne retourne pas de données.

SelectedItemTemplate

Définit le contenu à restituer pour l'élément de données sélectionné pour différencier l'élément sélectionné d'autres éléments.

AlternatingItemTemplate

Définit le contenu à restituer pour les éléments de remplacement pour simplifier la distinction entre des éléments consécutifs.

EditItemTemplate

Définit le contenu à restituer lorsqu'un élément est modifié. Le modèle EditItemTemplate est restitué au lieu du modèle ItemTemplate pour l'élément de données modifié.

InsertItemTemplate

Définit le contenu à restituer pour insérer un élément. Le modèle InsertItemTemplate est restitué au lieu d'un modèle ItemTemplate au démarrage ou à la fin des éléments affichés par le contrôle ListView. Vous pouvez spécifier l'emplacement où le modèle InsertItemTemplate est rendu à l'aide de la propriété InsertItemPosition du contrôle ListView.

Pour afficher la valeur d'un champ dans un modèle tel que ItemTemplate, utilisez une expression de liaison de données. Pour plus d'informations sur les expressions de liaison de données, consultez Vue d'ensemble des expressions de liaison de données.

Pour lier des contrôles d'entrée dans les modèles EditItemTemplate et InsertItemTemplate aux champs d'une source de données, vous pouvez utiliser des expressions de liaison bidirectionnelles. Cela permet au contrôle ListView d'extraire automatiquement les valeurs du contrôle d'entrée pour une opération de mise à jour ou d'insertion. Les expressions de liaison bidirectionnelles permettent également aux contrôles d'entrée dans un EditItemTemplate d'afficher automatiquement les valeurs de champ d'origine. Pour plus d'informations sur les expressions de liaison bidirectionnelles, consultez Liaison à des bases de données.

Liaison à une source de données

Le contrôle ListView peut être lié à un contrôle de source de données (tel que SqlDataSource ou ObjectDataSource) ou à toute source de données qui implémente l'interface System.Collections..::.IEnumerable, telle que System.Data..::.DataView, System.Collections..::.ArrayList, System.Collections.Generic..::.List<(Of <(T>)>) ou autres types de collection. Utilisez l'une des méthodes suivantes pour lier le contrôle ListView au type de source de données approprié :

  • Pour lier à un contrôle de source de données, affectez à la propriété DataSourceID du contrôle ListView la valeur ID du contrôle de source de données. Le contrôle ListView se lie automatiquement au contrôle de source de données spécifié et peut tirer parti des fonctionnalités du contrôle de source de données pour exécuter des fonctionnalités de tri, d'insertion, de mise à jour, de suppression et de pagination. Il s'agit de la méthode recommandée de liaison aux données.

  • Pour établir une liaison avec une source de données qui implémente l'interface System.Collections..::.IEnumerable, affectez par programme la propriété DataSource du contrôle ListView à la source de données, puis appelez la méthode DataBind. Lorsque vous utilisez cette technique, le contrôle ListView ne fournit pas de fonctionnalités intégrées de tri, de mise à jour, de suppression et de pagination. Vous devez fournir ces fonctionnalités en utilisant l'événement approprié.

Pour plus d'informations sur la liaison de données, consultez Accès aux données ASP.NET.

RemarqueRemarque

Le contrôle ListView peut être utilisé pour afficher des entrées d'utilisateur qui peuvent inclure un script client malveillant. Recherchez dans toutes les informations envoyées par un client un script exécutable, des instructions SQL ou tout autre code avant de les afficher dans votre application. Dans la mesure du possible, il est fortement recommandé que les valeurs soient encodées en HTML avant de les afficher dans ce contrôle. ASP.NET fournit une fonctionnalité de validation de demande d'entrée pour aider à bloquer les scripts et le HTML dans les entrées d'utilisateur. Vous pouvez également utiliser des contrôles de serveur de validation pour vérifier l'entrée d'utilisateur. Pour plus d'informations, consultez Introduction to the Validation Controls.

Opérations de données

Lorsque le contrôle ListView est lié à un contrôle de source de données, le contrôle ListView peut tirer parti des fonctionnalités de contrôle de source de données et fournir des fonctionnalités automatiques de tri, d'insertion, de mise à jour et de suppression.

RemarqueRemarque

Le contrôle ListView peut assurer la prise en charge requise pour trier, insérer, mettre à jour et supprimer avec d'autres types de sources de données. Toutefois, pour implémenter ces opérations, vous devez créer le code dans un gestionnaire d'événements approprié.

Comme le contrôle ListView utilise des modèles, il n'offre pas de moyen de générer automatiquement des boutons pour exécuter les opérations de mise à jour, de suppression, d'insertion, de tri ou de sélection. Vous devez inclure manuellement ces boutons dans le modèle approprié. Le contrôle ListView reconnaît certains boutons dont la propriété CommandName a une valeur spécifique. Le tableau suivant répertorie les boutons que le contrôle ListView reconnaît et leurs fonctions.

Button

Valeur de CommandName

Description

Cancel

"Cancel"

Annule une opération de modification ou d'insertion. Déclenche l'événement ItemCanceling.

Supprimer

"Delete"

Supprime l'enregistrement actuel de la source de données. Déclenche les événements ItemDeleted et ItemDeleting.

Select

"Select"

Affecte à la propriété SelectedIndex la valeur de la propriété DisplayIndex pour l'élément. Restitue le modèle SelectedItemTemplate pour l'élément. Déclenche les événements SelectedIndexChanging et SelectedIndexChanged.

Modifier

"Edit"

Met l'élément en mode Édition. Restitue le modèle EditItemTemplate pour l'élément. Déclenche l'événement ItemEditing.

Insert

"Insert"

Insère les valeurs liées du modèle InsertItemTemplate dans la source de données. Déclenche les événements ItemInserting et ItemInserted.

Update

"Update"

Met à jour l'enregistrement actif dans la source de données avec les valeurs liées du modèle EditItemTemplate. Déclenche les événements ItemUpdating et ItemUpdated.

Sort

"Sort"

Trie les colonnes répertoriées dans la propriété CommandArgument du bouton. Déclenche les événements Sorting et Sorted.

Contrairement au bouton Supprimer (lequel supprime immédiatement l'élément de données actuel), lorsque l'on clique sur le bouton Modifier, le contrôle ListView affiche l'élément actuel en mode Édition. En mode Édition, le contenu de la propriété EditItemTemplate est affiché pour l'élément de données actuel. En général, dans le modèle de modification d'élément, le bouton Modifier est remplacé par un bouton Mettre à jour et un bouton Annuler. Les contrôles d'entrée appropriés pour le type de données du champ (tels qu'un contrôle TextBox ou CheckBox) affichent aussi généralement la valeur d'un champ à modifier par l'utilisateur. Un clic sur le bouton Mettre à jour met à jour l'enregistrement dans la source de données et un clic sur le bouton Annuler annule l'opération d'édition.

La fonctionnalité d'insertion est activée lorsque la propriété InsertItemPosition a la valeur FirstItem ou LastItem. Cette propriété définit où le modèle InsertItemTemplate est restitué pour l'élément d'insertion. Le modèle d'élément d'insertion inclut en général un bouton Insérer et un bouton Annuler, et les contrôles d'entrée vides sont affichés pour que les utilisateurs entrent les valeurs pour le nouvel enregistrement. Cliquer sur le bouton Insérer permet d'insérer l'enregistrement dans la source de données, et cliquer sur le bouton Annuler efface tous les champs.

Tri

Le contrôle ListView permet aux utilisateurs de trier les éléments en cliquant sur le bouton Trier. La fonctionnalité de tri est définie dans la propriété CommandArgument du bouton qui contient les colonnes à trier.

Pagination

Au lieu d'afficher en même temps tous les enregistrements de la source de données, le contrôle ListView peut scinder les enregistrements en pages. Pour activer la pagination, associez un contrôle DataPager au contrôle ListView. Puis insérez un contrôle DataPager à l'intérieur du modèle LayoutTemplate. Ou bien, si le contrôle DataPager est à l'extérieur du contrôle ListView, affectez à la propriété PagedControlID la valeur ID du contrôle ListView.

Événements

Le tableau suivant répertorie les événements qui sont pris en charge par le contrôle ListView.

Événement

Description

ItemCanceling

Se produit en cas de clic sur le bouton Annuler (bouton dont la propriété CommandName a la valeur "Cancel"), mais avant que le contrôle ListView n'annule l'opération d'insertion ou de modification. Cet événement est souvent utilisé pour arrêter l'opération d'annulation.

ItemCommand

Se produit lors d'un clic sur le bouton d'un contrôle ListView. Cet événement est souvent utilisé pour exécuter une tâche personnalisée lorsque l'on clique sur un bouton dans le contrôle.

ItemCreated

Se produit lorsqu'un nouvel élément est créé dans le contrôle ListView. Cet événement est souvent utilisé pour modifier le contenu d'un élément lors de sa création.

ItemDataBound

Se produit lorsqu'un élément de données est lié à des données dans le contrôle ListView. Cet événement est souvent utilisé pour modifier le contenu d'un élément lorsqu'il est lié à des données.

ItemDeleted

Se produit lorsque l'on clique sur un bouton Supprimer (bouton dont la propriété CommandName a la valeur "Delete") ou lorsque la méthode DeleteItem est appelée, après que le contrôle ListView ait supprimé l'enregistrement dans la source de données. Cet événement est souvent utilisé pour vérifier les résultats de l'opération de suppression.

ItemDeleting

Se produit lorsque l'on clique sur un bouton Supprimer (bouton dont la propriété CommandName a la valeur "Delete") ou lorsque la méthode DeleteItem est appelée, mais avant que le contrôle ListView n'ait supprimé l'enregistrement dans la source de données. Cet événement est souvent utilisé pour confirmer ou annuler l'opération de suppression.

ItemEditing

Se produit lorsque l'on clique sur un bouton Modifier (bouton dont la propriété CommandName a la valeur "Edit"), mais avant que le contrôle ListView passé en mode Édition. Cet événement est souvent utilisé pour annuler l'opération de modification.

ItemInserted

Se produit lorsque l'on clique sur un bouton Insérer (bouton dont la propriété CommandName a la valeur "Insert") ou lorsque la méthode InsertNewItem est appelée, après que le contrôle ListView ait inséré le nouvel enregistrement à partir de la source de données. Cet événement est souvent utilisé pour vérifier les résultats de l'opération d'insertion.

ItemInserting

Se produit lorsque l'on clique sur un bouton Insérer (bouton dont la propriété CommandName a la valeur "Insert") ou que l'on appelle la méthode InsertNewItem, mais avant que le contrôle ListView n'insère l'enregistrement. Cet événement est souvent utilisé pour annuler l'opération d'insertion ou pour modifier ou valider les valeurs du nouvel élément.

ItemUpdated

Se produit lorsque l'on clique sur le bouton Mettre à jour (bouton dont la propriété CommandName a la valeur "Update") ou lors de l'appel de la méthode UpdateItem, après que le contrôle ListView ait mis l'enregistrement à jour. Cet événement est souvent utilisé pour vérifier les résultats de l'opération de mise à jour.

ItemUpdating

Se produit lorsque l'on clique sur le bouton Mettre à jour (bouton dont la propriété CommandName a la valeur "Update") ou lors de l'appel de la méthode UpdateItem, mais avant que le contrôle ListView ait mis l'enregistrement à jour. Cet événement est souvent utilisé pour annuler l'opération de mise à jour ou pour modifier ou valider les valeurs de l'élément modifié.

LayoutCreated

Se produit lorsque le modèle LayoutTemplate est créé dans un contrôle ListView. Cet événement est souvent utilisé pour effectuer une tâche après création du modèle.

PagePropertiesChanged

Se produit lorsque les propriétés de page sont modifiées, après que le contrôle ListView ait défini les nouvelles valeurs.

PagePropertiesChanging

Se produit lorsque les propriétés de pages de données sont modifiées, mais avant que le contrôle ListView n'ai défini les nouvelles valeurs.

SelectedIndexChanged

Se produit lorsque l'on clique sur un bouton Sélectionner (bouton dont la propriété CommandName à la valeur "Select"), après que le contrôle ListView ait traité l'opération de sélection. Cet événement est souvent utilisé pour exécuter une tâche personnalisée après qu'un élément ait été sélectionné dans le contrôle.

SelectedIndexChanging

Se produit lorsque l'on clique sur un bouton Sélectionner (bouton dont la propriété CommandName à la valeur "Select"), mais avant que le contrôle ListView ait traité l'opération de sélection. Cet événement est souvent utilisé pour annuler l'opération de sélection.

Sorted

Se produit lorsque l'on clique sur un bouton Trier (bouton dont la propriété CommandName a la valeur "Sort") ou lors de l'appel de la méthode Sort, après que le contrôle ListView ait géré l'opération de tri. Cet événement est utilisé en général pour effectuer une tâche personnalisée après qu'un utilisateur ait cliqué sur un bouton Trier et que les données ont été triées.

Sorting

Se produit lorsque l'on clique sur un bouton Trier (bouton dont la propriété CommandName a la valeur "Sort") ou lors de l'appel de la méthode Sort, mais avant que le contrôle ListView ait géré l'opération de tri. Cet événement est souvent utilisé pour annuler l'opération de tri ou exécuter un programme de tri personnalisé.

Syntaxe déclarative

<asp:ListView
    ConvertEmptyStringToNull="True|False"
    DataKeyNames="string"
    DataMember="string"
    DataSource="string"
    DataSourceID="string"
    EditIndex="integer"
    Enabled="True|False"
    EnableTheming="True|False"
    EnableViewState="True|False"
    GroupPlaceholderID="string"
    GroupItemCount="integer"
    ID="string"
    InsertItemPosition="None|FirstItem|LastItem"
    ItemPlaceholderID="string"
    OnDataBinding="DataBinding event handler"
    OnDataBound="DataBound event handler"
    OnDisposed="Disposed event handler"
    OnInit="Init event handler"
    OnItemCanceling="ItemCanceling event handler"
    OnItemCommand="ItemCommand event handler"
    OnItemCreated="ItemCreated event handler"
    OnItemDataBound="ItemDataBound event handler"
    OnItemDeleted="ItemDeleted event handler"
    OnItemDeleting="ItemDeleting event handler"
    OnItemEditing="ItemEditing event handler"
    OnItemInserted="ItemInserted event handler"
    OnItemInserting="ItemInserting event handler"
    OnItemUpdated="ItemUpdated event handler"
    OnItemUpdating="ItemUpdating event handler"
    OnLayoutCreated="LayoutCreated event handler"
    OnLoad="Load event handler"
    OnPagePropertiesChanged="PagePropertiesChanged event handler"
    OnPagePropertiesChanging="PagePropertiesChanging event handler"
    OnPreRender="PreRender event handler"
    OnSelectedIndexChanged="SelectedIndexChanged event handler"
    OnSelectedIndexChanging="SelectedIndexChanging event handler"
    OnSorted="Sorted event handler"
    OnSorting="Sorting event handler"
    OnUnload="Unload event handler"
    runat="server"
    SelectedIndex="integer"
    SkinID="string"
    Style="string"
    Visible="True|False"
>
        <AlternatingItemTemplate>
            <!-- child controls -->
        </AlternatingItemTemplate>
        <EditItemTemplate>
            <!-- child controls -->
        </EditItemTemplate>
        <EmptyDataTemplate>
            <!-- child controls -->
        </EmptyDataTemplate>
        <EmptyItemTemplate>
            <!-- child controls -->
        </EmptyItemTemplate>
        <GroupSeparatorTemplate>
            <!-- child controls -->
        </GroupSeparatorTemplate>
        <GroupTemplate>
            <!-- child controls -->
        </GroupTemplate>
        <InsertItemTemplate>
            <!-- child controls -->
        </InsertItemTemplate>
        <ItemSeparatorTemplate>
            <!-- child controls -->
        </ItemSeparatorTemplate>
        <ItemTemplate>
            <!-- child controls -->
        </ItemTemplate>
        <LayoutTemplate>
                <!-- child controls -->
        </LayoutTemplate>
        <SelectedItemTemplate>
            <!-- child controls -->
        </SelectedItemTemplate>
</asp:ListView>

L'exemple suivant montre comment utiliser le contrôle ListView pour afficher des enregistrements d'une base de données en utilisant un tableau HTML. Les valeurs sont récupérées à l'aide d'un contrôle LinqDataSource.

Visual Basic
<%@ Page language="VB" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Example</title>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Example</h3>

      <asp:ListView ID="VendorsListView"
        DataSourceID="VendorsDataSource"
        DataKeyNames="VendorID"
        runat="server">
        <LayoutTemplate>
          <table cellpadding="2" width="640px" border="1" ID="tbl1" runat="server">
            <tr runat="server" style="background-color: #98FB98">
              <th runat="server">ID</th>
              <th runat="server">Account Number</th>
              <th runat="server">Name</th>
              <th runat="server">Preferred Vendor</th>
            </tr>
            <tr runat="server" id="itemPlaceholder" />
          </table>
          <asp:DataPager ID="DataPager1" runat="server">
            <Fields>
              <asp:NumericPagerField />
            </Fields>
          </asp:DataPager>
        </LayoutTemplate>
        <ItemTemplate>
          <tr runat="server">
            <td>
              <asp:Label ID="VendorIDLabel" runat="server" Text='<%# Eval("VendorID") %>' />
            </td>
            <td>
              <asp:Label ID="AccountNumberLabel" runat="server" Text='<%# Eval("AccountNumber") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%# Eval("Name") %>' /></td>
            <td>
              <asp:CheckBox ID="PreferredCheckBox" runat="server" 
                Checked='<%# Eval("PreferredVendorStatus") %>' Enabled="False" />
            </td>
          </tr>
        </ItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects   -->
      <!-- to the AdventureWorks sample database. Add a LINQ     -->
      <!-- to SQL class to the project to map to a table in      -->
      <!-- the database.                                         -->
      <asp:LinqDataSource ID="VendorsDataSource" runat="server" 
        ContextTypeName="AdventureWorksClassesDataContext" 
        Select="new (VendorID, AccountNumber, Name, PreferredVendorStatus)" 
        TableName="Vendors" Where="ActiveFlag == @ActiveFlag">
        <WhereParameters>
          <asp:Parameter DefaultValue="true" Name="ActiveFlag" Type="Boolean" />
        </WhereParameters>
      </asp:LinqDataSource>

    </form>
  </body>
</html>
C#
<%@ Page language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Example</title>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Example</h3>

      <asp:ListView ID="VendorsListView"
        DataSourceID="VendorsDataSource"
        DataKeyNames="VendorID"
        runat="server">
        <LayoutTemplate>
          <table cellpadding="2" width="640px" border="1" ID="tbl1" runat="server">
            <tr runat="server" style="background-color: #98FB98">
              <th runat="server">ID</th>
              <th runat="server">Account Number</th>
              <th runat="server">Name</th>
              <th runat="server">Preferred Vendor</th>
            </tr>
            <tr runat="server" id="itemPlaceholder" />
          </table>
          <asp:DataPager ID="DataPager1" runat="server">
            <Fields>
              <asp:NumericPagerField />
            </Fields>
          </asp:DataPager>
        </LayoutTemplate>
        <ItemTemplate>
          <tr runat="server">
            <td>
              <asp:Label ID="VendorIDLabel" runat="server" Text='<%# Eval("VendorID") %>' />
            </td>
            <td>
              <asp:Label ID="AccountNumberLabel" runat="server" Text='<%# Eval("AccountNumber") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%# Eval("Name") %>' /></td>
            <td>
              <asp:CheckBox ID="PreferredCheckBox" runat="server" 
                Checked='<%# Eval("PreferredVendorStatus") %>' Enabled="False" />
            </td>
          </tr>
        </ItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects   -->
      <!-- to the AdventureWorks sample database. Add a LINQ     -->
      <!-- to SQL class to the project to map to a table in      -->
      <!-- the database.                                         -->
      <asp:LinqDataSource ID="VendorsDataSource" runat="server" 
        ContextTypeName="AdventureWorksClassesDataContext" 
        Select="new (VendorID, AccountNumber, Name, PreferredVendorStatus)" 
        TableName="Vendors" Where="ActiveFlag == @ActiveFlag">
        <WhereParameters>
          <asp:Parameter DefaultValue="true" Name="ActiveFlag" Type="Boolean" />
        </WhereParameters>
      </asp:LinqDataSource>

    </form>
  </body>
</html>

L'exemple suivant montre comment utiliser le contrôle ListView pour afficher des valeurs dans une mise en page fluide à l'aide de l'élément div. Les valeurs sont récupérées à l'aide d'un contrôle SqlDataSource.

Visual Basic
<%@ Page language="VB" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Flow Layout Example</title>
    <style type="text/css">
      .plainBox {
          font-family: Verdana, Arial, sans-serif;
          font-size: 11px;
          background: #ffffff;
          border:1px solid #336666;
          }
    </style>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Flow Layout Example</h3>

      Select the color:
      <asp:DropDownList ID="ColorList" runat="server" 
        AutoPostBack="True" 
        DataSourceID="ColorDataSource" 
        DataTextField="Color" 
        DataValueField="Color">
      </asp:DropDownList><br /><br />

      <asp:ListView runat="server" ID="ProductListView"
        DataSourceID="ProductsDataSource"
        DataKeyNames="ProductID">
        <LayoutTemplate>
          <div runat="server" id="lstProducts">
            <div runat="server" id="itemPlaceholder" />
          </div>
          <asp:DataPager ID="DataPager1" runat="server" PageSize="5" >
            <Fields>
              <asp:NextPreviousPagerField 
                ButtonType="Button"
                ShowFirstPageButton="True" 
                ShowLastPageButton="True" />
            </Fields>
          </asp:DataPager>
        </LayoutTemplate>
        <ItemTemplate>
          <asp:Image ID="ProductImage" runat="server"
            ImageUrl='<%# "~/images/thumbnails/" & Eval("ThumbnailPhotoFileName") %>' />            
          <div class="plainBox" runat="server">
            <asp:HyperLink ID="ProductLink" runat="server" Text='<%# Eval("Name") %>' 
              NavigateUrl='<%# "ProductDetails.aspx?productID=" & Eval("ProductID") %>' />
            <br /><br />
            <b>Price:</b> 
            <asp:Label ID="PriceLabel" runat="server" Text='<%# Eval("ListPrice", "{0:c}")%>' /> <br />
          </div>
          <br />
        </ItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects      -->
      <!-- to the AdventureWorks sample database. Use an ASP.NET    -->
      <!-- expression to retrieve the connection string value       -->
      <!-- from the Web.config file.                                -->
      <asp:SqlDataSource ID="ProductsDataSource" runat="server" 
        ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>"                        
        SelectCommand="SELECT P.ProductID, P.Name, P.Color, P.ListPrice, 
          PF.ThumbnailPhotoFileName, P.Size
          FROM Production.Product AS P 
          INNER JOIN Production.ProductProductPhoto AS PPF ON P.ProductID = PPF.ProductID 
          INNER JOIN Production.ProductPhoto AS PF ON PPF.ProductPhotoID = PF.ProductPhotoID
          WHERE P.Color = @Color" >
        <SelectParameters>
          <asp:ControlParameter ControlID="ColorList" Name="Color" 
            PropertyName="SelectedValue" />
        </SelectParameters>
      </asp:SqlDataSource>

      <asp:SqlDataSource ID="ColorDataSource" runat="server" 
        ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>" 
        SelectCommand="SELECT DISTINCT Color FROM Production.Product">
      </asp:SqlDataSource>

    </form>
  </body>
</html>
C#
<%@ Page language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Flow Layout Example</title>
    <style type="text/css">
      .plainBox {
          font-family: Verdana, Arial, sans-serif;
          font-size: 11px;
          background: #ffffff;
          border:1px solid #336666;
          }
    </style>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Flow Layout Example</h3>

      Select the color:
      <asp:DropDownList ID="ColorList" runat="server" 
        AutoPostBack="True" 
        DataSourceID="ColorDataSource" 
        DataTextField="Color" 
        DataValueField="Color">
      </asp:DropDownList><br /><br />

      <asp:ListView runat="server" ID="ProductListView"
        DataSourceID="ProductsDataSource"
        DataKeyNames="ProductID">
        <LayoutTemplate>
          <div runat="server" id="lstProducts">
            <div runat="server" id="itemPlaceholder" />
          </div>
          <asp:DataPager runat="server" PageSize="5" >
            <Fields>
              <asp:NextPreviousPagerField 
                ButtonType="Button"
                ShowFirstPageButton="True" 
                ShowLastPageButton="True" />
            </Fields>
          </asp:DataPager>
        </LayoutTemplate>
        <ItemTemplate>
          <asp:Image ID="ProductImage" runat="server"
            ImageUrl='<%# "~/images/thumbnails/" + Eval("ThumbnailPhotoFileName") %>' />            
          <div class="plainBox" runat="server">
            <asp:HyperLink ID="ProductLink" runat="server" Text='<%# Eval("Name") %>' 
              NavigateUrl='<%# "ProductDetails.aspx?productID=" + Eval("ProductID") %>' />
            <br /><br />
            <b>Price:</b> 
            <asp:Label ID="PriceLabel" runat="server" Text='<%# Eval("ListPrice", "{0:c}")%>' /> <br />
          </div>
          <br />
        </ItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects      -->
      <!-- to the AdventureWorks sample database. Use an ASP.NET    -->
      <!-- expression to retrieve the connection string value       -->
      <!-- from the Web.config file.                                -->
      <asp:SqlDataSource ID="ProductsDataSource" runat="server" 
        ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>"                        
        SelectCommand="SELECT P.ProductID, P.Name, P.Color, P.ListPrice, 
          PF.ThumbnailPhotoFileName, P.Size
          FROM Production.Product AS P 
          INNER JOIN Production.ProductProductPhoto AS PPF ON P.ProductID = PPF.ProductID 
          INNER JOIN Production.ProductPhoto AS PF ON PPF.ProductPhotoID = PF.ProductPhotoID
          WHERE P.Color = @Color" >
        <SelectParameters>
          <asp:ControlParameter ControlID="ColorList" Name="Color" 
            PropertyName="SelectedValue" />
        </SelectParameters>
      </asp:SqlDataSource>

      <asp:SqlDataSource ID="ColorDataSource" runat="server" 
        ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>" 
        SelectCommand="SELECT DISTINCT Color FROM Production.Product">
      </asp:SqlDataSource>

    </form>
  </body>
</html>

L'exemple suivant montre comment utiliser le contrôle ListView pour insérer, supprimer et mettre des enregistrements à jour.

Note de sécuritéNote de sécurité

Cet exemple a une zone de texte qui accepte l'entrée d'utilisateur, ce qui constitue une menace éventuelle pour la sécurité. Par défaut, les pages Web ASP.NET vérifient que l'entrée d'utilisateur n'inclut pas de script ni d'éléments HTML. Pour plus d'informations, consultez Vue d'ensemble des attaques de script.

Visual Basic
<%@ Page language="VB" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Example</title>
    <style type="text/css">
        .EditItem { background-color:#8FBC8F;}
        .SelectedItem {    background-color:#9ACD32; }
        .InsertItem { background-color:#FFFACD;}
    </style>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Example</h3>

      <h5>Departments</h5>

      <asp:ListView ID="DepartmentsListView" 
        DataSourceID="DepartmentsDataSource" 
        DataKeyNames="DepartmentID"
        ConvertEmptyStringToNull="true"
        InsertItemPosition="LastItem"
        runat="server">
        <LayoutTemplate>
          <table cellpadding="2" runat="server" id="tblDepartments" width="640px" cellspacing="0">
            <tr runat="server" id="itemPlaceholder" />
          </table>
        </LayoutTemplate>
        <ItemTemplate>
          <tr runat="server">
            <td>
              <asp:Button ID="SelectButton" runat="server" Text="Select" CommandName="Select" />
              <asp:Button ID="EditButton" runat="server" Text="Edit" CommandName="Edit" />
            </td>
            <td>
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%#Eval("Name") %>' />
            </td>
            <td>
              <asp:Label ID="GroupNameLabel" runat="server" Text='<%#Eval("GroupName") %>' />
            </td>
          </tr>
        </ItemTemplate>
        <SelectedItemTemplate>
          <tr class="SelectedItem" runat="server">
            <td>
              <asp:Button ID="DeleteButton" runat="server" Text="Delete" CommandName="Delete" />
              <asp:Button ID="EditButton" runat="server" Text="Edit" CommandName="Edit" />
            </td>
            <td>
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%#Eval("Name") %>' />
            </td>
            <td>
              <asp:Label ID="GroupNameLabel" runat="server" Text='<%#Eval("GroupName") %>' />
            </td>
          </tr>
        </SelectedItemTemplate>
        <EditItemTemplate>
          <tr class="EditItem">
            <td>
              <asp:Button ID="UpdateButton" runat="server" CommandName="Update" Text="Update" />
              <asp:Button ID="CancelButton" runat="server" CommandName="Cancel" Text="Cancel" />
            </td>
            <td>
              <b>ID</b><br />
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label runat="server" ID="NameLabel" AssociatedControlID="NameTextBox" 
                Text="Name" Font-Bold="true"/><br />
              <asp:TextBox ID="NameTextBox" runat="server" Text='<%#Bind("Name") %>' />
            </td>
            <td>
              <asp:Label runat="server" ID="GroupNameLabel" AssociatedControlID="GroupNameTextBox" 
                Text="Group Name" Font-Bold="true" /><br />
              <asp:TextBox ID="GroupNameTextBox" runat="server" 
                Width="200px"
                Text='<%#Bind("GroupName") %>' />
              <br />
            </td>
          </tr>
        </EditItemTemplate>
        <InsertItemTemplate>
          <tr class="InsertItem">
            <td colspan="2">
              <asp:Button ID="InsertButton" runat="server" CommandName="Insert" Text="Insert" />
              <asp:Button ID="CancelButton" runat="server" CommandName="Cancel" Text="Cancel" />
            </td>
            <td>
              <asp:Label runat="server" ID="NameLabel" AssociatedControlID="NameTextBox" 
                Text="Name" Font-Bold="true"/><br />
              <asp:TextBox ID="NameTextBox" runat="server" Text='<%#Bind("Name") %>' /><br />
            </td>
            <td>
              <asp:Label runat="server" ID="GroupNameLabel" AssociatedControlID="GroupNameTextBox" 
                Text="Group Name" Font-Bold="true" /><br />                
              <asp:TextBox ID="GroupNameTextBox" runat="server" Text='<%#Bind("GroupName") %>' />
            </td>
          </tr>
        </InsertItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects      -->
      <!-- to the AdventureWorks sample database. Use an ASP.NET    -->
      <!-- expression to retrieve the connection string value       -->
      <!-- from the Web.config file.                                -->            
      <asp:SqlDataSource ID="DepartmentsDataSource" runat="server" 
            ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>"
            SelectCommand="SELECT DepartmentID, Name, GroupName FROM HumanResources.Department"
            UpdateCommand="UPDATE HumanResources.Department 
                SET Name = @Name, GroupName = @GroupName WHERE (DepartmentID = @DepartmentID)"            
            DeleteCommand="DELETE FROM HumanResources.Department 
                WHERE (DepartmentID = @DepartmentID)" 
            InsertCommand="INSERT INTO HumanResources.Department(Name, GroupName) 
                VALUES (@Name, @GroupName)">
      </asp:SqlDataSource>

    </form>
  </body>
</html>
C#
<%@ Page language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html  >
  <head id="Head1" runat="server">
    <title>ListView Example</title>
    <style type="text/css">
        .EditItem { background-color:#8FBC8F;}
        .SelectedItem {    background-color:#9ACD32; }
        .InsertItem { background-color:#FFFACD;}
    </style>
  </head>
  <body>
    <form id="form1" runat="server">

      <h3>ListView Example</h3>

      <h5>Departments</h5>

      <asp:ListView ID="DepartmentsListView" 
        DataSourceID="DepartmentsDataSource" 
        DataKeyNames="DepartmentID"
        ConvertEmptyStringToNull="true"
        InsertItemPosition="LastItem"
        runat="server">
        <LayoutTemplate>
          <table cellpadding="2" runat="server" id="tblDepartments" width="640px" cellspacing="0">
            <tr runat="server" id="itemPlaceholder" />
          </table>
        </LayoutTemplate>
        <ItemTemplate>
          <tr runat="server">
            <td>
              <asp:Button ID="SelectButton" runat="server" Text="Select" CommandName="Select" />
              <asp:Button ID="EditButton" runat="server" Text="Edit" CommandName="Edit" />
            </td>
            <td>
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%#Eval("Name") %>' />
            </td>
            <td>
              <asp:Label ID="GroupNameLabel" runat="server" Text='<%#Eval("GroupName") %>' />
            </td>
          </tr>
        </ItemTemplate>
        <SelectedItemTemplate>
          <tr class="SelectedItem" runat="server">
            <td>
              <asp:Button ID="DeleteButton" runat="server" Text="Delete" CommandName="Delete" />
              <asp:Button ID="EditButton" runat="server" Text="Edit" CommandName="Edit" />
            </td>
            <td>
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label ID="NameLabel" runat="server" Text='<%#Eval("Name") %>' />
            </td>
            <td>
              <asp:Label ID="GroupNameLabel" runat="server" Text='<%#Eval("GroupName") %>' />
            </td>
          </tr>
        </SelectedItemTemplate>
        <EditItemTemplate>
          <tr class="EditItem">
            <td>
              <asp:Button ID="UpdateButton" runat="server" CommandName="Update" Text="Update" />
              <asp:Button ID="CancelButton" runat="server" CommandName="Cancel" Text="Cancel" />
            </td>
            <td>
              <b>ID</b><br />
              <asp:Label ID="IDLabel" runat="server" Text='<%#Eval("DepartmentID") %>' />
            </td>
            <td>
              <asp:Label runat="server" ID="NameLabel" AssociatedControlID="NameTextBox" 
                Text="Name" Font-Bold="true"/><br />
              <asp:TextBox ID="NameTextBox" runat="server" Text='<%#Bind("Name") %>' />
            </td>
            <td>
              <asp:Label runat="server" ID="GroupNameLabel" AssociatedControlID="GroupNameTextBox" 
                Text="Group Name" Font-Bold="true" /><br />
              <asp:TextBox ID="GroupNameTextBox" runat="server" 
                Width="200px"
                Text='<%#Bind("GroupName") %>' />
              <br />
            </td>
          </tr>
        </EditItemTemplate>
        <InsertItemTemplate>
          <tr class="InsertItem">
            <td colspan="2">
              <asp:Button ID="InsertButton" runat="server" CommandName="Insert" Text="Insert" />
              <asp:Button ID="CancelButton" runat="server" CommandName="Cancel" Text="Cancel" />
            </td>
            <td>
              <asp:Label runat="server" ID="NameLabel" AssociatedControlID="NameTextBox" 
                Text="Name" Font-Bold="true"/><br />
              <asp:TextBox ID="NameTextBox" runat="server" Text='<%#Bind("Name") %>' /><br />
            </td>
            <td>
              <asp:Label runat="server" ID="GroupNameLabel" AssociatedControlID="GroupNameTextBox" 
                Text="Group Name" Font-Bold="true" /><br />                
              <asp:TextBox ID="GroupNameTextBox" runat="server" Text='<%#Bind("GroupName") %>' />
            </td>
          </tr>
        </InsertItemTemplate>
      </asp:ListView>

      <!-- This example uses Microsoft SQL Server and connects      -->
      <!-- to the AdventureWorks sample database. Use an ASP.NET    -->
      <!-- expression to retrieve the connection string value       -->
      <!-- from the Web.config file.                                -->            
      <asp:SqlDataSource ID="DepartmentsDataSource" runat="server" 
            ConnectionString="<%$ ConnectionStrings:AdventureWorks_DataConnectionString %>"
            SelectCommand="SELECT DepartmentID, Name, GroupName FROM HumanResources.Department"
            UpdateCommand="UPDATE HumanResources.Department 
                SET Name = @Name, GroupName = @GroupName WHERE (DepartmentID = @DepartmentID)"            
            DeleteCommand="DELETE FROM HumanResources.Department 
                WHERE (DepartmentID = @DepartmentID)" 
            InsertCommand="INSERT INTO HumanResources.Department(Name, GroupName) 
                VALUES (@Name, @GroupName)">
      </asp:SqlDataSource>

    </form>
  </body>
</html>

.NET Framework

Pris en charge dans : 4, 3.5

Windows 7, Windows Vista SP1 ou ultérieur, Windows XP SP3, Windows Server 2008 (installation minimale non prise en charge), Windows Server 2008 R2 (installation minimale prise en charge avec SP1 ou version ultérieure), Windows Server 2003 SP2

Le .NET Framework ne prend pas en charge toutes les versions de chaque plateforme. Pour obtenir la liste des versions prises en charge, consultez Configuration requise du .NET Framework.
Tous les membres static (Shared en Visual Basic) publics de ce type sont thread-safe. Il n'est pas garanti que les membres d'instance soient thread-safe.
Contenu de la communauté   Qu'est-ce que le Contenu de la communauté ?
Ajouter du contenu RSS  Annotations
Processing
© 2012 Microsoft. Tous droits réservés. Conditions d'utilisation | Marques | Confidentialité
Page view tracker