目前还不太清楚您要做什么以及究竟什么不起作用。但我会尝试回答一些假设:
- 您希望表单根据 isInModifyMode 仅基于简单的回发事件进行更改
- “父表单控件的点击事件”是指触发回发的单个按钮
- 您正在使用 C# 和代码隐藏
原理很简单,有很多方法可以做我认为你所要求的。一种方法是基本上将事件绑定到按钮以设置控件的 isInModifyMode 属性。在控件本身中,让属性的 setter 调用更新显示的方法。这在以下非常基本且不完美的示例中得到了说明:
Default.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<%@ Register Src="WebUserControl.ascx" TagName="WebUserControl" TagPrefix="uc1" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>Untitled Page</title>
</head>
<body>
<form id="form1" runat="server">
<uc1:WebUserControl ID="WebUserControl1" runat="server" isInModifyMode="false" />
<asp:Button ID="EditButton" runat="server" Text="Edit" />
</form>
</body>
</html>
Default.aspx.cs
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class _Default : System.Web.UI.Page
{
protected override void OnInit(EventArgs e)
{
// Assign the handler for the edit button click event
EditButton.Click += new EventHandler(EditButton_Click);
base.OnInit(e);
}
/// <summary>
/// Edit button click handler
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
void EditButton_Click(object sender, EventArgs e)
{
WebUserControl1.isInModifyMode = true;
}
}
WebUserControl1.ascx
<%@ Control Language="C#" AutoEventWireup="true" CodeFile="WebUserControl.ascx.cs" Inherits="WebUserControl" %>
<asp:PlaceHolder ID="ReadOnlyModePlaceholder" runat="server">
<p>Read Only Mode</p>
</asp:PlaceHolder>
<asp:PlaceHolder ID="EditModePlaceholder" runat="server" Visible="false">
<p>Edit Mode</p>
</asp:PlaceHolder>
WebUserControl1.ascx.cs
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class WebUserControl : System.Web.UI.UserControl
{
/// <summary>
/// Changes the display mode by toggling the appropriate controls on or off
/// based on the isInModifyMode property
/// </summary>
private void SetDisplayMode()
{
if (!this.isInModifyMode)
{
// Render as not modify
ReadOnlyModePlaceholder.Visible = true;
EditModePlaceholder.Visible = false;
}
else
{
// Render as modify
ReadOnlyModePlaceholder.Visible = false;
EditModePlaceholder.Visible = true;
}
}
/// <summary>
/// Determines whether or not the control should be displayed in edit mode or not.
/// </summary>
public bool isInModifyMode
{
get
{
if (ViewState["isInModifyMode"] != null)
return (bool)ViewState["isInModifyMode"];
else
return false;
}
set
{
ViewState["isInModifyMode"] = value;
// Since we're possibly changing modes, call
// the SetDisplayMode() method to update the display
SetDisplayMode();
}
}
protected void Page_Load(object sender, EventArgs e)
{
// Set the display mode on the initial load
if (!IsPostBack)
SetDisplayMode();
}
}