[.net] 操纵自如-页面内的配合与通信
程序员文章站
2023-12-27 13:25:57
.net的页面看似一个整体,却可能是由很多不同的区域组合而来的,常常用到的母版页、用户控件就是最鲜明的例子。 然而在一个页面内的元素要形成一个整体,就少不了控件之间的通信与...
.net的页面看似一个整体,却可能是由很多不同的区域组合而来的,常常用到的母版页、用户控件就是最鲜明的例子。
然而在一个页面内的元素要形成一个整体,就少不了控件之间的通信与传值,本文是个人在不断的使用过程中总结的一些东西,有谬误或有更好的解决方案,还请提出来。
在写这篇文章的过程中我做了一些一示例,以作佐证。这些示例的目的都是 在“a”中 把 “b”中 的一个label的值改变。
这样的做法有什么意义?
比如说你在masterpage中含有一个gridview,在aspx改变了一些数据,而这些数据正是影响到masterpage中的gridview的呈现内容,那么你就有必要在aspx中通知masterpage更新了。本文的目的就是要说,如何去通知它的更新。
本文包括以下几个部分:
1、aspx与ascx的通信
2、master与aspx的之间的通信
3、master中的ascx 与 master中的aspx通信
4、ascx与ascx之间的通信
1、aspx与ascx的通信
一个简单的示例,在这个例子中,一共有两个文件:usercontrol-page.aspx和webusercontrol3.ascx,两个文件之中均含有一个textbox、label和一个button
在这里,我们使用a和b来简称前者和后者。
要求的效果是:点击a中的button,能将a中textbox中的值赋给b中的label;反之,点击b中的butoon,要将b中textbox中的值赋给a中的label。
也就是说,它们两个能改变对方的控件内容。
首先说a->b
这是很简单的,在ascx中写一个公共的方法,在aspx中调用就行了。
[copy to clipboard] [ - ]code:
//这是在ascx中的方法,该方法将参数_value的值赋给label。
public void setselect(string _value)
{
lblmessage.text = _value;
}
在aspx中直接调用它
[copy to clipboard] [ - ]code:
protected void btnset_click(object sender, eventargs e)
{
webusercontrol3_1.setselect(txtvalue.text);// webusercontrol3_1是用户控件的id
}
可能大家看得不是很明白,不过总之,在aspx中可以调用ascx中的公共方法,传入想传的参数,就ok了。
如果倒过来,由b->a。
在ascx中改变aspx中的一个label,也只换种方式
[copy to clipboard] [ - ]code:
label lblmessage= (label)page.findcontrol("lblmessage");
lblmessage.text = txtvalue.text;
也就是说,可以在ascx中查找当前aspx页的控件id,找到了,直接赋个值就行了。反正,只要找到这个控件,用起来就好像自己的一样。
2、master与aspx的通信
在master中访问aspx中的东西也是查找控件,和ascx中查找aspx中差不多
[copy to clipboard] [ - ]code:
label lblmessage= (label)contentplaceholder1.findcontrol("lblmessage");
lblmessage.text = txtvalue.text;
倒过来,aspx可以调用masterpage的公共方法
[copy to clipboard] [ - ]code:
masterpage master = (masterpage)page.master;//转换为masterpage的类型
master.setvalue(txtvalue.text);//调用masterpage的方法
3、master中的ascx 与 master中的aspx通信
从master中的ascx到master中的aspx,需要通过master,查找contentplaceholder,再查找label
[copy to clipboard] [ - ]code:
masterpage master = (masterpage)page.master;
label _lblmessage = (label)master.findcontrol("contentplaceholder1").findcontrol("lblmessage");
_lblmessage.text = txtvalue.text;
aspx要想与masterpage的ascx联系,要先得到master,再查找ascx,再查找label。
[copy to clipboard] [ - ]code:
masterpage master = (masterpage)page.master;
label lblmessage=(label)master.findcontrol("webusercontrol4_1").findcontrol("lblmessage");
lblmessage.text = txtvalue.text;
这个双方互通是一样的原理哦。
4、ascx与ascx之间的通信
这应该是最常见的情况,前段时间做的项目,分两个区域,用户在a区域从事活动,b区域记录下他活动的信息,这两个区域都是用户控件。
一种方法是从a.ascx中查找aspx,再查找b.ascx,再查找label。
这种方向理论上的行得通的,不过我没试,因为这种方法必须考虑b控件在a中的id,我却不想与id发生任何关系。
所以我用接口。
假设现有webusercontrol2.ascx想操纵webusercontrol1.ascx中的控件。
在app_code中新建一个iusercontrol1.cs
内容:
[copy to clipboard] [ - ]code:
public interface iusercontrol1
{
void setselect(string value);
}
在webusercontrol1.ascx继承该接口,并实现其方法。
[copy to clipboard] [ - ]code:
public partial class usercontrol_webusercontrol1 : system.web.ui.usercontrol, iusercontrol1
{
public void setselect(string _value)
{
lblmessage.text = _value;
}
}
然后直接在webusercontrol2.ascx调用webusercontrol1.ascx中的方法
[copy to clipboard] [ - ]code:
iusercontrol1 usercontrol1 = (iusercontrol1)page.findcontrol("webusercontrol1_1");//转化到接口去
usercontrol1.setselect(txtvalue.text);//setselect是webusercontrol1.ascx中的方法,调用它。
这实际上是很好的一种方法,这样来做,其它类型的控件间通信应该都能实现,在那几天,我还一直沾沾自喜着呢。通过这一样一个例子,也发现接口确实不简单,真的是一个“接口”。
.net的partial类的引入使用我的可以在各个文件中实现一个,最后合并在一起,而通过这些小技巧,又可以把各部分联系起来,成为一个真正的“整体”。
我的blog:http://99love.blueidea.com。
其相关程序都附在附件中。
然而在一个页面内的元素要形成一个整体,就少不了控件之间的通信与传值,本文是个人在不断的使用过程中总结的一些东西,有谬误或有更好的解决方案,还请提出来。
在写这篇文章的过程中我做了一些一示例,以作佐证。这些示例的目的都是 在“a”中 把 “b”中 的一个label的值改变。
这样的做法有什么意义?
比如说你在masterpage中含有一个gridview,在aspx改变了一些数据,而这些数据正是影响到masterpage中的gridview的呈现内容,那么你就有必要在aspx中通知masterpage更新了。本文的目的就是要说,如何去通知它的更新。
本文包括以下几个部分:
1、aspx与ascx的通信
2、master与aspx的之间的通信
3、master中的ascx 与 master中的aspx通信
4、ascx与ascx之间的通信
1、aspx与ascx的通信
一个简单的示例,在这个例子中,一共有两个文件:usercontrol-page.aspx和webusercontrol3.ascx,两个文件之中均含有一个textbox、label和一个button
在这里,我们使用a和b来简称前者和后者。
要求的效果是:点击a中的button,能将a中textbox中的值赋给b中的label;反之,点击b中的butoon,要将b中textbox中的值赋给a中的label。
也就是说,它们两个能改变对方的控件内容。
首先说a->b
这是很简单的,在ascx中写一个公共的方法,在aspx中调用就行了。
[copy to clipboard] [ - ]code:
//这是在ascx中的方法,该方法将参数_value的值赋给label。
public void setselect(string _value)
{
lblmessage.text = _value;
}
在aspx中直接调用它
[copy to clipboard] [ - ]code:
protected void btnset_click(object sender, eventargs e)
{
webusercontrol3_1.setselect(txtvalue.text);// webusercontrol3_1是用户控件的id
}
可能大家看得不是很明白,不过总之,在aspx中可以调用ascx中的公共方法,传入想传的参数,就ok了。
如果倒过来,由b->a。
在ascx中改变aspx中的一个label,也只换种方式
[copy to clipboard] [ - ]code:
label lblmessage= (label)page.findcontrol("lblmessage");
lblmessage.text = txtvalue.text;
也就是说,可以在ascx中查找当前aspx页的控件id,找到了,直接赋个值就行了。反正,只要找到这个控件,用起来就好像自己的一样。
2、master与aspx的通信
在master中访问aspx中的东西也是查找控件,和ascx中查找aspx中差不多
[copy to clipboard] [ - ]code:
label lblmessage= (label)contentplaceholder1.findcontrol("lblmessage");
lblmessage.text = txtvalue.text;
倒过来,aspx可以调用masterpage的公共方法
[copy to clipboard] [ - ]code:
masterpage master = (masterpage)page.master;//转换为masterpage的类型
master.setvalue(txtvalue.text);//调用masterpage的方法
3、master中的ascx 与 master中的aspx通信
从master中的ascx到master中的aspx,需要通过master,查找contentplaceholder,再查找label
[copy to clipboard] [ - ]code:
masterpage master = (masterpage)page.master;
label _lblmessage = (label)master.findcontrol("contentplaceholder1").findcontrol("lblmessage");
_lblmessage.text = txtvalue.text;
aspx要想与masterpage的ascx联系,要先得到master,再查找ascx,再查找label。
[copy to clipboard] [ - ]code:
masterpage master = (masterpage)page.master;
label lblmessage=(label)master.findcontrol("webusercontrol4_1").findcontrol("lblmessage");
lblmessage.text = txtvalue.text;
这个双方互通是一样的原理哦。
4、ascx与ascx之间的通信
这应该是最常见的情况,前段时间做的项目,分两个区域,用户在a区域从事活动,b区域记录下他活动的信息,这两个区域都是用户控件。
一种方法是从a.ascx中查找aspx,再查找b.ascx,再查找label。
这种方向理论上的行得通的,不过我没试,因为这种方法必须考虑b控件在a中的id,我却不想与id发生任何关系。
所以我用接口。
假设现有webusercontrol2.ascx想操纵webusercontrol1.ascx中的控件。
在app_code中新建一个iusercontrol1.cs
内容:
[copy to clipboard] [ - ]code:
public interface iusercontrol1
{
void setselect(string value);
}
在webusercontrol1.ascx继承该接口,并实现其方法。
[copy to clipboard] [ - ]code:
public partial class usercontrol_webusercontrol1 : system.web.ui.usercontrol, iusercontrol1
{
public void setselect(string _value)
{
lblmessage.text = _value;
}
}
然后直接在webusercontrol2.ascx调用webusercontrol1.ascx中的方法
[copy to clipboard] [ - ]code:
iusercontrol1 usercontrol1 = (iusercontrol1)page.findcontrol("webusercontrol1_1");//转化到接口去
usercontrol1.setselect(txtvalue.text);//setselect是webusercontrol1.ascx中的方法,调用它。
这实际上是很好的一种方法,这样来做,其它类型的控件间通信应该都能实现,在那几天,我还一直沾沾自喜着呢。通过这一样一个例子,也发现接口确实不简单,真的是一个“接口”。
.net的partial类的引入使用我的可以在各个文件中实现一个,最后合并在一起,而通过这些小技巧,又可以把各部分联系起来,成为一个真正的“整体”。
我的blog:http://99love.blueidea.com。
其相关程序都附在附件中。