Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / xsp / System / Web / UI / WebControls / CompositeDataBoundControl.cs / 2 / 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
- ResourceSet.cs
- PageClientProxyGenerator.cs
- MenuItemStyleCollection.cs
- RepeaterCommandEventArgs.cs
- TabItem.cs
- RichTextBox.cs
- TextSelectionHelper.cs
- NativeMethods.cs
- CurrentTimeZone.cs
- DbProviderServices.cs
- VirtualPath.cs
- TraversalRequest.cs
- StaticResourceExtension.cs
- CapabilitiesState.cs
- ReflectionPermission.cs
- ChameleonKey.cs
- HasCopySemanticsAttribute.cs
- WebPartVerb.cs
- ToolTipService.cs
- MDIControlStrip.cs
- BamlCollectionHolder.cs
- XLinq.cs
- Soap12ProtocolReflector.cs
- XmlWriterSettings.cs
- UTF8Encoding.cs
- BitmapEffectvisualstate.cs
- TrackingServices.cs
- BamlReader.cs
- Light.cs
- WorkflowPageSetupDialog.cs
- DataGridViewCellValueEventArgs.cs
- DrawingVisual.cs
- CompilerGlobalScopeAttribute.cs
- FlowDocumentView.cs
- QueryOutputWriter.cs
- StreamReader.cs
- PackageProperties.cs
- DispatcherOperation.cs
- Collection.cs
- FileAuthorizationModule.cs
- XmlEncodedRawTextWriter.cs
- TextDecorationCollection.cs
- DataServiceConfiguration.cs
- SqlBuilder.cs
- FixedSOMImage.cs
- SafeNativeMethods.cs
- XdrBuilder.cs
- WorkflowOperationBehavior.cs
- WindowsRichEditRange.cs
- MetadataPropertyCollection.cs
- TextRange.cs
- CreateRefExpr.cs
- PathHelper.cs
- ActivityExecutionContext.cs
- ContextMenuAutomationPeer.cs
- SchemaSetCompiler.cs
- IndicCharClassifier.cs
- BindToObject.cs
- Sql8ConformanceChecker.cs
- StringAnimationUsingKeyFrames.cs
- AppSecurityManager.cs
- FlowLayoutPanelDesigner.cs
- PartialClassGenerationTask.cs
- ProcessProtocolHandler.cs
- PixelShader.cs
- DocumentViewerConstants.cs
- SettingsBindableAttribute.cs
- XmlSubtreeReader.cs
- SchemaDeclBase.cs
- _ShellExpression.cs
- LineBreakRecord.cs
- MultipartContentParser.cs
- ParserExtension.cs
- SecurityHelper.cs
- CodeTypeParameter.cs
- RegexStringValidator.cs
- SerializerProvider.cs
- ParameterCollection.cs
- OleServicesContext.cs
- SiteMapPath.cs
- log.cs
- SoapTypeAttribute.cs
- HttpCachePolicyElement.cs
- Rotation3DAnimationBase.cs
- WorkflowItemsPresenter.cs
- MemberCollection.cs
- Assembly.cs
- SqlDataReaderSmi.cs
- ColorPalette.cs
- StateMachineWorkflowDesigner.cs
- BooleanKeyFrameCollection.cs
- NavigationService.cs
- HttpContextWrapper.cs
- WrappedKeySecurityToken.cs
- ClockGroup.cs
- MergePropertyDescriptor.cs
- DefaultValueMapping.cs
- TableLayoutStyle.cs
- FileUpload.cs
- NameValueConfigurationElement.cs