Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / DEVDIV / depot / DevDiv / releases / whidbey / QFE / 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. //------------------------------------------------------------------------------ //// 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.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ReadWriteObjectLock.cs
- TableStyle.cs
- TableProviderWrapper.cs
- EncryptedType.cs
- Latin1Encoding.cs
- GenerateHelper.cs
- LongTypeConverter.cs
- MD5CryptoServiceProvider.cs
- HtmlTextArea.cs
- RuntimeHandles.cs
- AssertHelper.cs
- ExpressionEditorSheet.cs
- ShaperBuffers.cs
- HtmlObjectListAdapter.cs
- AuthenticationSection.cs
- securitycriticaldata.cs
- StorageScalarPropertyMapping.cs
- CodeGotoStatement.cs
- DetailsViewCommandEventArgs.cs
- XmlTextWriter.cs
- XmlSchemaValidator.cs
- SymbolType.cs
- FirstMatchCodeGroup.cs
- TabletCollection.cs
- RoleExceptions.cs
- CompositeControl.cs
- DatatypeImplementation.cs
- TraceContextRecord.cs
- recordstate.cs
- ValidatorCompatibilityHelper.cs
- StaticFileHandler.cs
- StrongNameKeyPair.cs
- TableRowCollection.cs
- MetadataItemCollectionFactory.cs
- LateBoundBitmapDecoder.cs
- StorageEntitySetMapping.cs
- DesignConnection.cs
- BinaryQueryOperator.cs
- WindowsScrollBar.cs
- GlyphInfoList.cs
- LocalizableResourceBuilder.cs
- FolderBrowserDialog.cs
- UnsafeNativeMethods.cs
- HtmlDocument.cs
- ChooseAction.cs
- CompoundFileDeflateTransform.cs
- DetailsViewDeletedEventArgs.cs
- SAPIEngineTypes.cs
- DataGridPageChangedEventArgs.cs
- ConstructorBuilder.cs
- FloaterBaseParagraph.cs
- MimeWriter.cs
- XmlDocument.cs
- CqlIdentifiers.cs
- OdbcConnectionFactory.cs
- CngKey.cs
- SpecularMaterial.cs
- DomainConstraint.cs
- ResourcesGenerator.cs
- xdrvalidator.cs
- FunctionMappingTranslator.cs
- AutoGeneratedField.cs
- PolicyManager.cs
- SupportsEventValidationAttribute.cs
- PermissionSetEnumerator.cs
- DataTemplate.cs
- DelegatedStream.cs
- ConfigurationSettings.cs
- recordstatefactory.cs
- Module.cs
- AnchorEditor.cs
- ToolBarPanel.cs
- GestureRecognizer.cs
- Perspective.cs
- RepeatButtonAutomationPeer.cs
- TokenFactoryBase.cs
- ObjectFactoryCodeDomTreeGenerator.cs
- FileDialogCustomPlace.cs
- DataSourceSelectArguments.cs
- TempFiles.cs
- ConfigurationSection.cs
- CorrelationResolver.cs
- WindowsEditBox.cs
- DBSchemaRow.cs
- RawTextInputReport.cs
- AppSettingsExpressionBuilder.cs
- AlternateView.cs
- ItemContainerGenerator.cs
- MsmqBindingElementBase.cs
- PasswordDeriveBytes.cs
- PaperSize.cs
- SolidColorBrush.cs
- BuildProvider.cs
- ParseChildrenAsPropertiesAttribute.cs
- MessageDescription.cs
- Axis.cs
- TextElementAutomationPeer.cs
- DateTimeEditor.cs
- ToolStripManager.cs
- UTF32Encoding.cs