Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / xsp / System / Web / UI / WebControls / CompositeDataBoundControl.cs / 1305376 / CompositeDataBoundControl.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls { using System; using System.Collections; public abstract class CompositeDataBoundControl : DataBoundControl, INamingContainer { internal const string ItemCountViewStateKey = "_!ItemCount"; public override ControlCollection Controls { get { EnsureChildControls(); return base.Controls; } } ////// Overriden by DataBoundControl to determine if the control should /// recreate its control hierarchy based on values in view state. /// If the control hierarchy should be created, i.e. view state does /// exist, it calls CreateChildControls with a dummy (empty) data source /// which is usable for enumeration purposes only. /// protected internal override void CreateChildControls() { Controls.Clear(); object controlCount = ViewState[ItemCountViewStateKey]; if (controlCount == null && RequiresDataBinding) { EnsureDataBound(); } if (controlCount != null && ((int)controlCount) != -1) { DummyDataSource dummyDataSource = new DummyDataSource((int)controlCount); CreateChildControls(dummyDataSource, false); ClearChildViewState(); } } ////// Performs the work of creating the control hierarchy based on a data source. /// When dataBinding is true, the specified data source contains real /// data, and the data is supposed to be pushed into the UI. /// When dataBinding is false, the specified data source is a dummy data /// source, that allows enumerating the right number of items, but the items /// themselves are null and do not contain data. In this case, the recreated /// control hierarchy reinitializes its state from view state. /// It enables a DataBoundControl to encapsulate the logic of creating its /// control hierarchy in both modes into a single code path. /// /// /// The data source to be used to enumerate items. /// /// /// Whether the method has been called from DataBind or not. /// ////// The number of items created based on the data source. Put another way, its /// the number of items enumerated from the data source. /// protected abstract int CreateChildControls(IEnumerable dataSource, bool dataBinding); ////// Overriden by DataBoundControl to use its properties to determine the real /// data source that the control should bind to. It then clears the existing /// control hierarchy, and calls createChildControls to create a new control /// hierarchy based on the resolved data source. /// The implementation resolves various data source related properties to /// arrive at the appropriate IEnumerable implementation to use as the real /// data source. /// When resolving data sources, the DataSourceControlID takes highest precedence. /// In this mode, DataMember is used to access the appropriate list from the /// DataControl. /// If DataSourceControlID is not set, the value of the DataSource property is used. /// In this second alternative, DataMember is used to extract the appropriate /// list if the control has been handed an IListSource as a data source. /// protected internal override void PerformDataBinding(IEnumerable data) { base.PerformDataBinding(data); Controls.Clear(); ClearChildViewState(); TrackViewState(); int controlCount = CreateChildControls(data, true); ChildControlsCreated = true; ViewState[ItemCountViewStateKey] = controlCount; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls { using System; using System.Collections; public abstract class CompositeDataBoundControl : DataBoundControl, INamingContainer { internal const string ItemCountViewStateKey = "_!ItemCount"; public override ControlCollection Controls { get { EnsureChildControls(); return base.Controls; } } ////// Overriden by DataBoundControl to determine if the control should /// recreate its control hierarchy based on values in view state. /// If the control hierarchy should be created, i.e. view state does /// exist, it calls CreateChildControls with a dummy (empty) data source /// which is usable for enumeration purposes only. /// protected internal override void CreateChildControls() { Controls.Clear(); object controlCount = ViewState[ItemCountViewStateKey]; if (controlCount == null && RequiresDataBinding) { EnsureDataBound(); } if (controlCount != null && ((int)controlCount) != -1) { DummyDataSource dummyDataSource = new DummyDataSource((int)controlCount); CreateChildControls(dummyDataSource, false); ClearChildViewState(); } } ////// Performs the work of creating the control hierarchy based on a data source. /// When dataBinding is true, the specified data source contains real /// data, and the data is supposed to be pushed into the UI. /// When dataBinding is false, the specified data source is a dummy data /// source, that allows enumerating the right number of items, but the items /// themselves are null and do not contain data. In this case, the recreated /// control hierarchy reinitializes its state from view state. /// It enables a DataBoundControl to encapsulate the logic of creating its /// control hierarchy in both modes into a single code path. /// /// /// The data source to be used to enumerate items. /// /// /// Whether the method has been called from DataBind or not. /// ////// The number of items created based on the data source. Put another way, its /// the number of items enumerated from the data source. /// protected abstract int CreateChildControls(IEnumerable dataSource, bool dataBinding); ////// Overriden by DataBoundControl to use its properties to determine the real /// data source that the control should bind to. It then clears the existing /// control hierarchy, and calls createChildControls to create a new control /// hierarchy based on the resolved data source. /// The implementation resolves various data source related properties to /// arrive at the appropriate IEnumerable implementation to use as the real /// data source. /// When resolving data sources, the DataSourceControlID takes highest precedence. /// In this mode, DataMember is used to access the appropriate list from the /// DataControl. /// If DataSourceControlID is not set, the value of the DataSource property is used. /// In this second alternative, DataMember is used to extract the appropriate /// list if the control has been handed an IListSource as a data source. /// protected internal override void PerformDataBinding(IEnumerable data) { base.PerformDataBinding(data); Controls.Clear(); ClearChildViewState(); TrackViewState(); int controlCount = CreateChildControls(data, true); ChildControlsCreated = true; ViewState[ItemCountViewStateKey] = controlCount; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- TileBrush.cs
- ProcessManager.cs
- ModifierKeysConverter.cs
- RSAPKCS1SignatureDeformatter.cs
- MailSettingsSection.cs
- ModuleElement.cs
- PathSegment.cs
- AdapterUtil.cs
- ContentPropertyAttribute.cs
- PagedControl.cs
- ImageSourceValueSerializer.cs
- SystemWebExtensionsSectionGroup.cs
- TransferMode.cs
- TypeInfo.cs
- CodeParameterDeclarationExpressionCollection.cs
- SoapClientProtocol.cs
- RadioButton.cs
- ReferenceSchema.cs
- UserThread.cs
- EventLogStatus.cs
- XmlHierarchicalEnumerable.cs
- ServiceModelSecurityTokenRequirement.cs
- TransformCryptoHandle.cs
- ValueSerializer.cs
- FocusWithinProperty.cs
- InputScope.cs
- SeverityFilter.cs
- InvalidOleVariantTypeException.cs
- EntityDataSourceViewSchema.cs
- Column.cs
- XmlSiteMapProvider.cs
- ServiceAuthorizationElement.cs
- ComboBoxDesigner.cs
- TextAdaptor.cs
- diagnosticsswitches.cs
- DesignerVerb.cs
- AudioBase.cs
- SelectiveScrollingGrid.cs
- Base64Decoder.cs
- MailWriter.cs
- XmlnsCompatibleWithAttribute.cs
- UTF7Encoding.cs
- JournalEntry.cs
- IOException.cs
- TerminatorSinks.cs
- MetricEntry.cs
- Tracking.cs
- DataGridViewCellFormattingEventArgs.cs
- XPathAncestorIterator.cs
- MemberCollection.cs
- DrawingImage.cs
- DataMember.cs
- Perspective.cs
- XmlILOptimizerVisitor.cs
- AssociationSet.cs
- HtmlTextArea.cs
- TraceEventCache.cs
- DbMetaDataColumnNames.cs
- StopStoryboard.cs
- TemplateFactory.cs
- ScriptResourceInfo.cs
- DbExpressionVisitor.cs
- ResourceExpressionBuilder.cs
- ConfigurationSectionGroup.cs
- DataObjectMethodAttribute.cs
- PeerCollaboration.cs
- FolderBrowserDialog.cs
- PropertyGridEditorPart.cs
- AmbientProperties.cs
- OutputCacheSection.cs
- ElementsClipboardData.cs
- baseshape.cs
- MessageQueuePermissionEntry.cs
- HyperLinkField.cs
- ByteStream.cs
- Char.cs
- MembershipPasswordException.cs
- RemoveStoryboard.cs
- KeyGestureValueSerializer.cs
- AddInBase.cs
- SqlDataSourceConfigureFilterForm.cs
- CroppedBitmap.cs
- DesignerActionItem.cs
- RangeBaseAutomationPeer.cs
- ExpressionConverter.cs
- DiscoveryRequestHandler.cs
- AuthenticationService.cs
- Win32SafeHandles.cs
- ClickablePoint.cs
- UIElementAutomationPeer.cs
- StaticSiteMapProvider.cs
- AnnotationResourceChangedEventArgs.cs
- EntityCommandExecutionException.cs
- RawUIStateInputReport.cs
- ClientTargetCollection.cs
- SecUtil.cs
- Executor.cs
- ResXResourceReader.cs
- Matrix.cs
- Int32KeyFrameCollection.cs