Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / xsp / System / Web / UI / HtmlControls / HtmlInputRadioButton.cs / 1 / HtmlInputRadioButton.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * HtmlInputRadioButton.cs * * Copyright (c) 2000 Microsoft Corporation */ namespace System.Web.UI.HtmlControls { using System.ComponentModel; using System; using System.Collections; using System.Collections.Specialized; using System.Web; using System.Web.UI; using System.Security.Permissions; ////// [ DefaultEvent("ServerChange"), SupportsEventValidation, ] [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public class HtmlInputRadioButton : HtmlInputControl, IPostBackDataHandler { private static readonly object EventServerChange = new object(); /* * Creates an intrinsic Html INPUT type=radio control. */ public HtmlInputRadioButton() : base("radio") { } /* * Checked property. */ ////// The ///class defines the methods, /// properties, and events for the HtmlInputRadio control. This class allows /// programmatic access to the HTML <input type= /// radio> /// element on the server. /// /// [ WebCategory("Default"), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden) ] public bool Checked { get { string s = Attributes["checked"]; return((s != null) ? (s.Equals("checked")) : false); } set { if (value) Attributes["checked"] = "checked"; else Attributes["checked"] = null; } } ////// Gets or sets a value indicating whether a radio button is /// currently selected or not. /// ////// public override string Name { get { string s = Attributes["name"]; return ((s != null) ? s : String.Empty); } set { Attributes["name"] = MapStringAttributeToString(value); } } ////// Gets the value of the HTML /// Name attribute that will be rendered to the browser. /// ////// public override string Value { get { string val = base.Value; if (val.Length != 0) return val; val = ID; if (val != null) return val; // if specific value is not provided, use the UniqueID return UniqueID; } set { base.Value = value; } } // Value that gets rendered for the Name attribute internal override string RenderedNameAttribute { get { // For radio buttons, we must make the name unique, but can't just use the // UniqueID because all buttons in a group must have the same name. So // we replace the last part of the UniqueID with the group Name. string name = base.RenderedNameAttribute; string uid = UniqueID; int lastColon = uid.LastIndexOf(IdSeparator); if (lastColon >= 0) name = uid.Substring(0, lastColon+1) + name; return name; } } [ WebCategory("Action"), WebSysDescription(SR.Control_OnServerCheckChanged) ] public event EventHandler ServerChange { add { Events.AddHandler(EventServerChange, value); } remove { Events.RemoveHandler(EventServerChange, value); } } /* * This method is invoked just prior to rendering. */ ////// Gets or sets the contents of a text box. /// ////// /// protected internal override void OnPreRender(EventArgs e) { base.OnPreRender(e); if (Page != null && !Disabled) { Page.RegisterRequiresPostBack(this); Page.RegisterEnabledControl(this); } // if no change handler, no need to save posted property if (Events[EventServerChange] == null && !Disabled) { ViewState.SetItemDirty("checked",false); } } /* * Method used to raise the OnServerChange event. */ ////// protected virtual void OnServerChange(EventArgs e) { EventHandler handler = (EventHandler)Events[EventServerChange]; if (handler != null) handler(this, e); } ////// /// protected override void RenderAttributes(HtmlTextWriter writer) { if (Page != null) { Page.ClientScript.RegisterForEventValidation(Value, RenderedNameAttribute); } writer.WriteAttribute("value", Value); Attributes.Remove("value"); base.RenderAttributes(writer); } /* * Method of IPostBackDataHandler interface to process posted data. * RadioButton determines the posted radio group state. */ ////// /// bool IPostBackDataHandler.LoadPostData(string postDataKey, NameValueCollection postCollection) { return LoadPostData(postDataKey, postCollection); } ////// /// protected virtual bool LoadPostData(string postDataKey, NameValueCollection postCollection) { string postValue = postCollection[RenderedNameAttribute]; bool valueChanged = false; if ((postValue != null) && postValue.Equals(Value)) { if (Checked == false) { ValidateEvent(Value, RenderedNameAttribute); Checked = true; // only fire change event for RadioButton that is being checked valueChanged = true; } } else { if (Checked == true) { Checked = false; } } return valueChanged; } /* * Method of IPostBackDataHandler interface which is invoked whenever posted data * for a control has changed. RadioButton fires an OnServerChange event. */ ////// /// void IPostBackDataHandler.RaisePostDataChangedEvent() { RaisePostDataChangedEvent(); } ////// /// protected virtual void RaisePostDataChangedEvent() { OnServerChange(EventArgs.Empty); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * HtmlInputRadioButton.cs * * Copyright (c) 2000 Microsoft Corporation */ namespace System.Web.UI.HtmlControls { using System.ComponentModel; using System; using System.Collections; using System.Collections.Specialized; using System.Web; using System.Web.UI; using System.Security.Permissions; ////// [ DefaultEvent("ServerChange"), SupportsEventValidation, ] [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public class HtmlInputRadioButton : HtmlInputControl, IPostBackDataHandler { private static readonly object EventServerChange = new object(); /* * Creates an intrinsic Html INPUT type=radio control. */ public HtmlInputRadioButton() : base("radio") { } /* * Checked property. */ ////// The ///class defines the methods, /// properties, and events for the HtmlInputRadio control. This class allows /// programmatic access to the HTML <input type= /// radio> /// element on the server. /// /// [ WebCategory("Default"), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden) ] public bool Checked { get { string s = Attributes["checked"]; return((s != null) ? (s.Equals("checked")) : false); } set { if (value) Attributes["checked"] = "checked"; else Attributes["checked"] = null; } } ////// Gets or sets a value indicating whether a radio button is /// currently selected or not. /// ////// public override string Name { get { string s = Attributes["name"]; return ((s != null) ? s : String.Empty); } set { Attributes["name"] = MapStringAttributeToString(value); } } ////// Gets the value of the HTML /// Name attribute that will be rendered to the browser. /// ////// public override string Value { get { string val = base.Value; if (val.Length != 0) return val; val = ID; if (val != null) return val; // if specific value is not provided, use the UniqueID return UniqueID; } set { base.Value = value; } } // Value that gets rendered for the Name attribute internal override string RenderedNameAttribute { get { // For radio buttons, we must make the name unique, but can't just use the // UniqueID because all buttons in a group must have the same name. So // we replace the last part of the UniqueID with the group Name. string name = base.RenderedNameAttribute; string uid = UniqueID; int lastColon = uid.LastIndexOf(IdSeparator); if (lastColon >= 0) name = uid.Substring(0, lastColon+1) + name; return name; } } [ WebCategory("Action"), WebSysDescription(SR.Control_OnServerCheckChanged) ] public event EventHandler ServerChange { add { Events.AddHandler(EventServerChange, value); } remove { Events.RemoveHandler(EventServerChange, value); } } /* * This method is invoked just prior to rendering. */ ////// Gets or sets the contents of a text box. /// ////// /// protected internal override void OnPreRender(EventArgs e) { base.OnPreRender(e); if (Page != null && !Disabled) { Page.RegisterRequiresPostBack(this); Page.RegisterEnabledControl(this); } // if no change handler, no need to save posted property if (Events[EventServerChange] == null && !Disabled) { ViewState.SetItemDirty("checked",false); } } /* * Method used to raise the OnServerChange event. */ ////// protected virtual void OnServerChange(EventArgs e) { EventHandler handler = (EventHandler)Events[EventServerChange]; if (handler != null) handler(this, e); } ////// /// protected override void RenderAttributes(HtmlTextWriter writer) { if (Page != null) { Page.ClientScript.RegisterForEventValidation(Value, RenderedNameAttribute); } writer.WriteAttribute("value", Value); Attributes.Remove("value"); base.RenderAttributes(writer); } /* * Method of IPostBackDataHandler interface to process posted data. * RadioButton determines the posted radio group state. */ ////// /// bool IPostBackDataHandler.LoadPostData(string postDataKey, NameValueCollection postCollection) { return LoadPostData(postDataKey, postCollection); } ////// /// protected virtual bool LoadPostData(string postDataKey, NameValueCollection postCollection) { string postValue = postCollection[RenderedNameAttribute]; bool valueChanged = false; if ((postValue != null) && postValue.Equals(Value)) { if (Checked == false) { ValidateEvent(Value, RenderedNameAttribute); Checked = true; // only fire change event for RadioButton that is being checked valueChanged = true; } } else { if (Checked == true) { Checked = false; } } return valueChanged; } /* * Method of IPostBackDataHandler interface which is invoked whenever posted data * for a control has changed. RadioButton fires an OnServerChange event. */ ////// /// void IPostBackDataHandler.RaisePostDataChangedEvent() { RaisePostDataChangedEvent(); } ////// /// protected virtual void RaisePostDataChangedEvent() { OnServerChange(EventArgs.Empty); } } } // 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
- DrawingImage.cs
- regiisutil.cs
- Subtree.cs
- ImageAutomationPeer.cs
- SqlFunctionAttribute.cs
- HttpModuleCollection.cs
- DesignColumn.cs
- _AutoWebProxyScriptHelper.cs
- NumericExpr.cs
- DrawingAttributesDefaultValueFactory.cs
- SecurityTraceRecordHelper.cs
- Soap12ProtocolReflector.cs
- _FtpControlStream.cs
- PropertyPathConverter.cs
- RecordsAffectedEventArgs.cs
- DesignerSerializationVisibilityAttribute.cs
- IdleTimeoutMonitor.cs
- AssociationTypeEmitter.cs
- ExpressionCopier.cs
- OperatorExpressions.cs
- MetadataUtil.cs
- PoisonMessageException.cs
- CharEnumerator.cs
- WsatServiceAddress.cs
- XmlSchemaComplexContent.cs
- XmlQueryOutput.cs
- Atom10FormatterFactory.cs
- CssStyleCollection.cs
- ColumnClickEvent.cs
- XamlInt32CollectionSerializer.cs
- XmlSerializableReader.cs
- ScrollItemPatternIdentifiers.cs
- RightsManagementPermission.cs
- HttpInputStream.cs
- IdentityManager.cs
- HttpRuntime.cs
- StructureChangedEventArgs.cs
- OleDbParameterCollection.cs
- CngKey.cs
- Selection.cs
- OutputCacheSettings.cs
- _CommandStream.cs
- Border.cs
- XmlDigitalSignatureProcessor.cs
- StringPropertyBuilder.cs
- ColorConverter.cs
- KeyValueInternalCollection.cs
- PenThread.cs
- SingleAnimation.cs
- BatchWriter.cs
- CreateInstanceBinder.cs
- ConfigurationSectionGroupCollection.cs
- TraceInternal.cs
- DataColumn.cs
- TailCallAnalyzer.cs
- HttpWriter.cs
- LookupBindingPropertiesAttribute.cs
- WebPartActionVerb.cs
- UserControlAutomationPeer.cs
- XmlAutoDetectWriter.cs
- SelectQueryOperator.cs
- SynchronousChannelMergeEnumerator.cs
- CriticalFinalizerObject.cs
- HMACRIPEMD160.cs
- MissingManifestResourceException.cs
- DispatcherHooks.cs
- TypeElementCollection.cs
- GatewayDefinition.cs
- SqlUnionizer.cs
- DocumentPageTextView.cs
- WeakReference.cs
- BooleanAnimationUsingKeyFrames.cs
- SudsWriter.cs
- SQLUtility.cs
- AccessorTable.cs
- DataGridViewRowCancelEventArgs.cs
- DesignerTextBoxAdapter.cs
- BufferedGraphicsManager.cs
- DynamicEndpoint.cs
- ComponentResourceManager.cs
- MetadataCache.cs
- TypeBrowserDialog.cs
- CheckedListBox.cs
- ReadOnlyTernaryTree.cs
- UpDownBase.cs
- OutputCacheModule.cs
- TextContainerHelper.cs
- WinFormsUtils.cs
- AnonymousIdentificationModule.cs
- QilNode.cs
- LabelAutomationPeer.cs
- PageThemeBuildProvider.cs
- DrawingState.cs
- BmpBitmapDecoder.cs
- SQLDecimalStorage.cs
- NotifyCollectionChangedEventArgs.cs
- CodeTypeDeclarationCollection.cs
- RadioButton.cs
- ColorAnimationUsingKeyFrames.cs
- RepeatBehaviorConverter.cs