Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / DEVDIV / depot / DevDiv / releases / whidbey / QFE / ndp / fx / src / xsp / System / Web / UI / HtmlControls / HtmlButton.cs / 2 / HtmlButton.cs
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//-----------------------------------------------------------------------------
/*
* HtmlButton.cs
*
* Copyright (c) 2000 Microsoft Corporation
*/
namespace System.Web.UI.HtmlControls {
using System.ComponentModel;
using System;
using System.Collections;
using System.Web;
using System.Web.UI;
using System.Security.Permissions;
///
/// The
/// class defines the methods, properties and events for the
///
/// control. This
/// class allows programmatic access to the HTML <button> element
/// on the server.
///
[
DefaultEvent("ServerClick"),
SupportsEventValidation,
]
[AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)]
public class HtmlButton : HtmlContainerControl, IPostBackEventHandler {
private static readonly object EventServerClick = new object();
/*
* Creates an intrinsic Html BUTTON control.
*/
///
/// Initializes a new instance of a class.
///
public HtmlButton() : base("button") {
}
///
/// Gets or sets whether pressing the button causes page validation to fire. This defaults to True so that when
/// using validation controls, the validation state of all controls are updated when the button is clicked, both
/// on the client and the server. Setting this to False is useful when defining a cancel or reset button on a page
/// that has validators.
///
[
WebCategory("Behavior"),
DefaultValue(true),
]
public virtual bool CausesValidation {
get {
object b = ViewState["CausesValidation"];
return((b == null) ? true : (bool)b);
}
set {
ViewState["CausesValidation"] = value;
}
}
[
WebCategory("Behavior"),
DefaultValue(""),
WebSysDescription(SR.PostBackControl_ValidationGroup)
]
public virtual string ValidationGroup {
get {
string s = (string)ViewState["ValidationGroup"];
return((s == null) ? String.Empty : s);
}
set {
ViewState["ValidationGroup"] = value;
}
}
///
/// Occurs when the user clicks an control on the
/// browser.
///
[
WebCategory("Action"),
WebSysDescription(SR.HtmlControl_OnServerClick)
]
public event EventHandler ServerClick {
add {
Events.AddHandler(EventServerClick, value);
}
remove {
Events.RemoveHandler(EventServerClick, value);
}
}
///
protected internal override void OnPreRender(EventArgs e) {
base.OnPreRender(e);
if (Page != null && Events[EventServerClick] != null)
Page.RegisterPostBackScript();
}
/*
* Override to generate postback code for onclick.
*/
///
///
///
protected override void RenderAttributes(HtmlTextWriter writer) {
bool submitsProgramatically = (Events[EventServerClick] != null);
if (Page != null && submitsProgramatically) {
Util.WriteOnClickAttribute(
writer, this, false, true,
(CausesValidation && Page.GetValidators(ValidationGroup).Count > 0),
ValidationGroup);
}
base.RenderAttributes(writer);
}
///
/// Raises the
/// event.
///
protected virtual void OnServerClick(EventArgs e) {
EventHandler handler = (EventHandler)Events[EventServerClick];
if (handler != null) handler(this, e);
}
/*
* Method of IPostBackDataHandler interface to raise events on post back.
* Button fires an OnServerClick event.
*/
///
///
///
void IPostBackEventHandler.RaisePostBackEvent(string eventArgument) {
RaisePostBackEvent(eventArgument);
}
///
///
///
protected virtual void RaisePostBackEvent(string eventArgument) {
ValidateEvent(UniqueID, eventArgument);
if (CausesValidation) {
Page.Validate(ValidationGroup);
}
OnServerClick(EventArgs.Empty);
}
}
}
// 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.
//
//-----------------------------------------------------------------------------
/*
* HtmlButton.cs
*
* Copyright (c) 2000 Microsoft Corporation
*/
namespace System.Web.UI.HtmlControls {
using System.ComponentModel;
using System;
using System.Collections;
using System.Web;
using System.Web.UI;
using System.Security.Permissions;
///
/// The
/// class defines the methods, properties and events for the
///
/// control. This
/// class allows programmatic access to the HTML <button> element
/// on the server.
///
[
DefaultEvent("ServerClick"),
SupportsEventValidation,
]
[AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)]
public class HtmlButton : HtmlContainerControl, IPostBackEventHandler {
private static readonly object EventServerClick = new object();
/*
* Creates an intrinsic Html BUTTON control.
*/
///
/// Initializes a new instance of a class.
///
public HtmlButton() : base("button") {
}
///
/// Gets or sets whether pressing the button causes page validation to fire. This defaults to True so that when
/// using validation controls, the validation state of all controls are updated when the button is clicked, both
/// on the client and the server. Setting this to False is useful when defining a cancel or reset button on a page
/// that has validators.
///
[
WebCategory("Behavior"),
DefaultValue(true),
]
public virtual bool CausesValidation {
get {
object b = ViewState["CausesValidation"];
return((b == null) ? true : (bool)b);
}
set {
ViewState["CausesValidation"] = value;
}
}
[
WebCategory("Behavior"),
DefaultValue(""),
WebSysDescription(SR.PostBackControl_ValidationGroup)
]
public virtual string ValidationGroup {
get {
string s = (string)ViewState["ValidationGroup"];
return((s == null) ? String.Empty : s);
}
set {
ViewState["ValidationGroup"] = value;
}
}
///
/// Occurs when the user clicks an control on the
/// browser.
///
[
WebCategory("Action"),
WebSysDescription(SR.HtmlControl_OnServerClick)
]
public event EventHandler ServerClick {
add {
Events.AddHandler(EventServerClick, value);
}
remove {
Events.RemoveHandler(EventServerClick, value);
}
}
///
protected internal override void OnPreRender(EventArgs e) {
base.OnPreRender(e);
if (Page != null && Events[EventServerClick] != null)
Page.RegisterPostBackScript();
}
/*
* Override to generate postback code for onclick.
*/
///
///
///
protected override void RenderAttributes(HtmlTextWriter writer) {
bool submitsProgramatically = (Events[EventServerClick] != null);
if (Page != null && submitsProgramatically) {
Util.WriteOnClickAttribute(
writer, this, false, true,
(CausesValidation && Page.GetValidators(ValidationGroup).Count > 0),
ValidationGroup);
}
base.RenderAttributes(writer);
}
///
/// Raises the
/// event.
///
protected virtual void OnServerClick(EventArgs e) {
EventHandler handler = (EventHandler)Events[EventServerClick];
if (handler != null) handler(this, e);
}
/*
* Method of IPostBackDataHandler interface to raise events on post back.
* Button fires an OnServerClick event.
*/
///
///
///
void IPostBackEventHandler.RaisePostBackEvent(string eventArgument) {
RaisePostBackEvent(eventArgument);
}
///
///
///
protected virtual void RaisePostBackEvent(string eventArgument) {
ValidateEvent(UniqueID, eventArgument);
if (CausesValidation) {
Page.Validate(ValidationGroup);
}
OnServerClick(EventArgs.Empty);
}
}
}
// 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
- ShapingWorkspace.cs
- DataGridItemCollection.cs
- EdmItemError.cs
- coordinatorscratchpad.cs
- SocketInformation.cs
- CompiledRegexRunnerFactory.cs
- XmlElementAttributes.cs
- DataObject.cs
- RemotingService.cs
- ProfileSettingsCollection.cs
- FlowDocument.cs
- ProgramNode.cs
- BrowserDefinition.cs
- ListBoxItemWrapperAutomationPeer.cs
- XPathEmptyIterator.cs
- _UriSyntax.cs
- EmbossBitmapEffect.cs
- ListViewItemMouseHoverEvent.cs
- FunctionOverloadResolver.cs
- DynamicResourceExtension.cs
- WebEventTraceProvider.cs
- ConnectionManagementElement.cs
- ThicknessConverter.cs
- DocumentSequence.cs
- OrderedDictionary.cs
- ResourceExpressionEditor.cs
- DataObjectMethodAttribute.cs
- EncoderNLS.cs
- ExpressionVisitor.cs
- _UncName.cs
- JoinSymbol.cs
- RepeaterDesigner.cs
- AvTraceDetails.cs
- BridgeDataReader.cs
- DocumentViewerAutomationPeer.cs
- Trace.cs
- LinqDataView.cs
- EventLogPermissionEntryCollection.cs
- AttributedMetaModel.cs
- RegistrySecurity.cs
- SqlBooleanMismatchVisitor.cs
- ThreadAttributes.cs
- MenuItem.cs
- DetailsViewDeleteEventArgs.cs
- IPPacketInformation.cs
- CompletionProxy.cs
- Vector3DCollectionConverter.cs
- GPRECT.cs
- ReadOnlyCollection.cs
- SafeIUnknown.cs
- CounterCreationDataCollection.cs
- wmiprovider.cs
- XmlSerializerVersionAttribute.cs
- StaticSiteMapProvider.cs
- Block.cs
- DeploymentSection.cs
- LocatorPart.cs
- DataRowView.cs
- Form.cs
- XmlSchemaValidationException.cs
- QueryOpcode.cs
- sqlmetadatafactory.cs
- ObjectDataSourceStatusEventArgs.cs
- RefreshPropertiesAttribute.cs
- WindowsListViewItemStartMenu.cs
- MemberDescriptor.cs
- DefaultBindingPropertyAttribute.cs
- EdmSchemaError.cs
- XmlObjectSerializerReadContextComplexJson.cs
- SQLConvert.cs
- Visual.cs
- TargetInvocationException.cs
- FileUtil.cs
- RuntimeEnvironment.cs
- DataGridHelper.cs
- XmlExtensionFunction.cs
- BamlLocalizableResource.cs
- CommandEventArgs.cs
- Image.cs
- ReadOnlyKeyedCollection.cs
- IsolatedStorageFilePermission.cs
- IdentityValidationException.cs
- VirtualDirectoryMapping.cs
- UnsafeNativeMethods.cs
- WebPartConnectionsCancelVerb.cs
- DetailsViewAutoFormat.cs
- ClientBuildManagerCallback.cs
- IISMapPath.cs
- DbgCompiler.cs
- XPathAncestorQuery.cs
- ListBoxChrome.cs
- DataGridViewHitTestInfo.cs
- DesignTimeParseData.cs
- DBConnectionString.cs
- DoubleLinkList.cs
- PanningMessageFilter.cs
- DependencyProperty.cs
- BinaryCommonClasses.cs
- PageHandlerFactory.cs
- ManipulationDevice.cs