Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / xsp / System / Web / UI / WebControls / CompositeDataBoundControl.cs / 1 / CompositeDataBoundControl.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls { using System; using System.Collections; using System.Security.Permissions; [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] 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; using System.Security.Permissions; [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] 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
- GetWorkflowTree.cs
- RenderData.cs
- SortQuery.cs
- NavigatorInvalidBodyAccessException.cs
- PointAnimationUsingPath.cs
- Multiply.cs
- TypeToken.cs
- ApplicationInfo.cs
- ObjectDataSourceStatusEventArgs.cs
- ToolStripLabel.cs
- ObjectAnimationUsingKeyFrames.cs
- SHA256Managed.cs
- TraceHandlerErrorFormatter.cs
- QueryRewriter.cs
- RenamedEventArgs.cs
- IPEndPoint.cs
- ContractComponent.cs
- OperationCanceledException.cs
- Repeater.cs
- GridItemCollection.cs
- BaseTreeIterator.cs
- PaginationProgressEventArgs.cs
- ConnectivityStatus.cs
- TemplateBuilder.cs
- IdnElement.cs
- ComEventsSink.cs
- AffineTransform3D.cs
- login.cs
- WorkerRequest.cs
- IssuedSecurityTokenParameters.cs
- Util.cs
- MaskedTextProvider.cs
- AnnotationResource.cs
- MultipleViewPattern.cs
- TemplateXamlParser.cs
- GC.cs
- SatelliteContractVersionAttribute.cs
- TransportSecurityHelpers.cs
- FixUpCollection.cs
- CodeMemberMethod.cs
- OrderByLifter.cs
- ReceiveErrorHandling.cs
- BinaryUtilClasses.cs
- SimplePropertyEntry.cs
- DynamicRenderer.cs
- BindingMemberInfo.cs
- HostingEnvironmentException.cs
- CharacterBufferReference.cs
- SafeMILHandle.cs
- PathTooLongException.cs
- Padding.cs
- ItemAutomationPeer.cs
- MetadataItem.cs
- RectAnimationUsingKeyFrames.cs
- DataPagerCommandEventArgs.cs
- IisTraceWebEventProvider.cs
- DependentList.cs
- XmlIterators.cs
- TextBoxAutoCompleteSourceConverter.cs
- TableDesigner.cs
- X500Name.cs
- IdentityModelDictionary.cs
- FileDialog.cs
- SplitContainer.cs
- QilValidationVisitor.cs
- Gdiplus.cs
- prefixendpointaddressmessagefiltertable.cs
- ImageMapEventArgs.cs
- ProviderBase.cs
- XPathBuilder.cs
- TrackingExtract.cs
- ValidationHelpers.cs
- CellLabel.cs
- X509ChainPolicy.cs
- HandleRef.cs
- SAPICategories.cs
- SmiContext.cs
- XmlDocumentType.cs
- XpsFontSubsetter.cs
- arabicshape.cs
- Propagator.JoinPropagator.SubstitutingCloneVisitor.cs
- QueryStringConverter.cs
- ConfigXmlCDataSection.cs
- ConditionalAttribute.cs
- CacheVirtualItemsEvent.cs
- TraceSection.cs
- DebugView.cs
- StackSpiller.Generated.cs
- CryptoKeySecurity.cs
- BackgroundFormatInfo.cs
- ThreadNeutralSemaphore.cs
- DPAPIProtectedConfigurationProvider.cs
- sqlpipe.cs
- EdmMember.cs
- PocoPropertyAccessorStrategy.cs
- NullReferenceException.cs
- GeneralTransform3D.cs
- FilteredReadOnlyMetadataCollection.cs
- RichTextBox.cs
- DBSqlParserTableCollection.cs