关于在PHP中替代ASP.NET的UserControls?和php替代的问题就给大家分享到这里,感谢你花时间阅读本站内容,更多关于.net–Masterpage与Usercontrol与Custom
关于在PHP中替代ASP.NET的UserControls?和php 替代的问题就给大家分享到这里,感谢你花时间阅读本站内容,更多关于.net – Masterpage与Usercontrol与Customcontrol之间的区别、Asp.net UserControl LoadControl问题、ASP.NET UserControl 通信的具体实现、ASP.NET UserControl不初始化子控件等相关知识的信息别忘了在本站进行查找喔。
本文目录一览:- 在PHP中替代ASP.NET的UserControls?(php 替代)
- .net – Masterpage与Usercontrol与Customcontrol之间的区别
- Asp.net UserControl LoadControl问题
- ASP.NET UserControl 通信的具体实现
- ASP.NET UserControl不初始化子控件
在PHP中替代ASP.NET的UserControls?(php 替代)
我在ASP.NET中开发了许多Web应用程序,我在其中使用UserControl来管理页眉和页面的任何其他常见部分.现在我正在用PHP开发一个应用程序,有什么我可以用作UserControls的替代品吗?
我如何在PHP中实现类似的概念?
谢谢?
解决方法:
第二个答案在这里有点难以详细解释,就是建立自己的’UserControl’类. Classes将具有您需要的必要属性,并且具有将控件输出到屏幕的RenderHTML()方法.
.net – Masterpage与Usercontrol与Customcontrol之间的区别
解决方法
ASP.Net Custom controls vs. user controls: Are these two the same
母版页实际上是用户控件;您可以通过转到主页类的代码隐藏来验证这一点,右键单击类名并选择“转到定义”.你会看到这样的东西:
public class MasterPage : UserControl { ... }
用户控件便于显示使用单个项目重复的显示组件,例如菜单和面板.问题是,如果需要,它们不会生成.DLL并且必须手动复制到其他项目.
另一方面,自定义控件可以在单独的类库中创建,并根据需要在其他项目中重用.使用自定义控件时,必须完全在代码中创建显示工件,并且开发需要稍长的时间.
查看Microsoft的用户控件和自定义控件之间的比较:
http://support.microsoft.com/kb/893667
Asp.net UserControl LoadControl问题
我有一个超简单的用户控制(ascx)
<%@ Control Language="C#" AutoEventWireup="True" Inherits="Errordisplay" Codebehind="Errordisplay.ascx.cs" EnableViewState="false" %> <asp:Label runat="server" ID="lblTitle" /> <asp:Label runat="server" ID="lblDescription" />
与代码(c#)后面:
public partial class Errordisplay : System.Web.UI.UserControl { private Message _ErrorMessage; public Errordisplay() { } public Errordisplay(Message ErrorMessage) { _ErrorMessage = ErrorMessage; } protected override void OnPreRender(EventArgs e) { base.OnPreRender(e); if (_ErrorMessage != null) { lblTitle.Text = _ErrorMessage.Message; lblDescription.Text = _ErrorMessage.Description; } } }
在我的Web应用程序的其他地方,我将使用以下代码向用户控件添加一个实例:
divValidationIssues.Controls.Add(LoadControl(typeof(Errordisplay),new object[] { MessageDetails }));
我正在使用LoadControl的重载版本,因为我想将Message参数传递给构造函数.所有这一切似乎都可以正常工作.
但是,当在Errordisplay用户控件上触发OnPreRender()时,lblTitle和lblDescription变量都为空,尽管它们具有等价的标记.消息变量已正确填充.
任何人都可以说明为什么会发生这种情况吗?
谢谢
编辑:
为了清楚起见,我还会补充说,正在编程地将用户控件添加到页面的代码正在响应按钮按钮,所以“主机页面”已经通过Init,Page_Load进行,现在正在处理事件处理程序.
我们无法在早期的asp生命周期阶段添加用户控件,因为它们是响应于按钮单击事件而创建的.
解决方法
protected void Page_Load(object sender,EventArgs e) { if (_ErrorMessage != null) { lblTitle.Text = _ErrorMessage.Message; lblDescription.Text = _ErrorMessage.Description; } }
我了解到,LoadControl函数将控件加载到正在包含的页面的当前“状态”中.因此,Init,Page_Load等都作为LoadControl调用的一部分运行.
有趣的是,这个(未回答)asp.net论坛的帖子展现了与我遇到的相同的问题.
MSDN Forums Post
另外 – 从MSDN:
When you load a control into a container control,the container raises all of the added control’s events until it has caught up to the current event. However,the added control does not catch up with postback data processing. For an added control to participate in postback data processing,including validation,the control must be added in the Init event rather than in the Load event.
所以不要LoadControl正确的控制?
编辑:
好的,所以我在这里回答我自己的问题
我找到一个回复版本的论坛帖子,我链接到Here上面
基本上,答案是LoadControl(type,params)不能推断“页面前端”ascx来解析,因此它不会打扰任何控件.当您使用LoadControl(“ascx路径”)版本时,它被赋予页面前端,因此执行所有解析和初始化.
总而言之,我需要更改正在控制的代码,并将其拆分成单独的部分.即
Control ErrorCntrl = LoadControl("Errordisplay.ascx"); ErrorCntrl.ID = SomeID; (ErrorCntrl as Errordisplay).SetErrorMessage = MessageDetail; diverrorContainer.Controls.Add(ErrorCntrl);
它应该工作正常..它不像我以前的尝试一样整洁,但至少它会工作.
我仍然乐意提出上述建议.
干杯
ASP.NET UserControl 通信的具体实现
最近在SharePoint2007中用到了WebPart通信技术,个人觉得2007版本里面的ConnectionConsumer和ConnectionProvider没有2010版本那么好用,于是换了一种思想去实现通信:WebPart容器中装一个UserControl控件,这样只要UserControl可以通信,就实现了WebPart之间通信。
UserControl是用户自定义控件,我们可以在UserControl中注入事件,当一个UserControl触发某种事件,然后通过事件参数来传递数据,让其他UserControl获得这个事件传递过来的参数,实现通信。
下面简单演示一下两个UserControl进行通信
创建好一个类,两个UserControl和一个web页面。
这里分别是MyEventAgrs.cs,UCProvider.ascx,UCComsumer.ascx,Default.aspx。
MyEventAgrs.cs代码如下:
public delegate void MyEventHandle(object sender, MyEventAgrs args);
public class MyEventAgrs : EventArgs
{
public MyEventAgrs() { }
public string MyMsg { get; set; }
}
public delegate void MyEventHandle(object sender, MyEventAgrs args);
public class MyEventAgrs : EventArgs
{
public MyEventAgrs() { }
public string MyMsg { get; set; }
}
如果想传递其他对象时就只需要修改MyEventAgrs类的MyMsg方法。这里须继承EventArgs抽象类,用于存放事件参数值,另外需定义一个委托事件,然后在其他的地方使用。
UCProvider.ascx代码如下:
public partial class UCProvider : System.Web.UI.UserControl
{
public event MyEventHandle myHandle;
protected void Page_Load(object sender, EventArgs e)
{
this.DropDownList1.SelectedIndexChanged += new EventHandler(DropDownList1_SelectedIndexChanged);
}
void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
{
MyEventAgrs myEvent = new MyEventAgrs();
myEvent.MyMsg = DropDownList1.SelectedValue;
myHandle(this, myEvent);
} }
public partial class UCProvider : System.Web.UI.UserControl
{
public event MyEventHandle myHandle;
protected void Page_Load(object sender, EventArgs e)
{
this.DropDownList1.SelectedIndexChanged += new EventHandler(DropDownList1_SelectedIndexChanged);
}
void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
{
MyEventAgrs myEvent = new MyEventAgrs();
myEvent.MyMsg = DropDownList1.SelectedValue;
myHandle(this, myEvent);
} }