两个webpart控件之间进行通信
来源:互联网 发布:seo外包服务平台 编辑:程序博客网 时间:2024/05/16 02:19
1、为了使两个webpart控件之间进行通信,必须先声明一个公共的接口。往工程项目里增加一个叫ISelectedDate.vb的类文件,放在app_code目录下,写入如下代码:
Imports Microsoft.VisualBasic
Public Interface ISelectedDate
ReadOnly Property SelectedDate( ) As Date
End Interface
这里,我们返回一个只读的日期属性selectedDate.
2、再创建一个日历控件CalendarUC.ascx,其中拖拉一个普通的日历控件即可。然后写入如下代码:
Partial Class CalendarUC_ascx
Inherits System.Web.UI.UserControl
Implements ISelectedDate
Public ReadOnly Property SelectedDate( ) As Date Implements ISelectedDate.SelectedDate
Get
Return Calendar1.SelectedDate.Date
End Get
End Property
<ConnectionProvider("SelectedDate", "SelectedDate")> _
Public Function GetSelectedDate( ) As ISelectedDate
Return Me
End Function
End Class
上面的代码,首先实现了已经声明了的IselectedDate接口,要留意的是<ConnectionProvider("SelectedDate","SelectedDate")>中的写法。由于在这个例子中,日历控件要为其他的控件提供信息,因此,该日历控件是一个provider(提供者),而另外的接收信息的控件,是consumer(消费者)。而两者为了要通信,必须要提供一个通信接入点,就象一个电插头,要找到合适的电插板一样。因此,<ConnectionProvider("SelectedDate","SelectedDate")>中的第一个参数,定义了两者的接口点,第二个参数,则是要传递给consumer的参数,本例是selectedDate。
3、接下来,我们在已经做好的google.ascx控件的代码中,编写如下代码:
Private _selectedDate As ISelectedDate
<ConnectionConsumer("SelectedDate", "SelectedDate")> _
Sub setSearchText(ByVal SearchText As ISelectedDate)
Me._selectedDate = SearchText
End Sub
Protected Sub Page_PreRender(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.PreRender
If _selectedDate IsNot Nothing Then
txtSearch.Text = _selectedDate.SelectedDate.ToShortDateString
End If
End Sub
可以看到 <ConnectionConsumer("SelectedDate", "SelectedDate")>的定义必须和provider中的定义一样。
4、再修改如下代码,将两个控件的命名变得通俗易懂
<ZoneTemplate>
<uc1:Google title="Google Search" runat="server" ID="Google1" />
<uc3:CalendarUC title="Calendar Web Part" runat="server" ID="CalendarUC1" />
</ZoneTemplate>
5、最后,为了使两者能互相通信,必须在default.aspx页中修改如下代码:
<asp:WebPartManager ID="WebPartManager1" runat="server">
<StaticConnections>
<asp:WebPartConnection ID="Connection"
ProviderID="CalendarUC1"
ProviderConnectionPointID="SelectedDate"
ConsumerID="Google1"
ConsumerConnectionPointID="SelectedDate" />
</StaticConnections>
</asp:WebPartManager>
6、在页面代码中,增加一个radiobutton,用作显示connection模式,并写入如下代码:
Case 4 : WebPartManager1.DisplayMode = WebPartManager.ConnectDisplayMode
7、运行程序,选择connect displaymode模式。再选择GOOGLESEARCH的那个webpart控件,点右上角的"conenct"按钮,此时,会显示如下图所示,提示你要选择从那个控件中得到信息,这里选择日历控件,按确定。那么,当点选日历控件的某个日期值的时候,GOOGLE SEARCH的那个文本框里,就会显示相应的日期了。
Imports Microsoft.VisualBasic
Public Interface ISelectedDate
ReadOnly Property SelectedDate( ) As Date
End Interface
这里,我们返回一个只读的日期属性selectedDate.
2、再创建一个日历控件CalendarUC.ascx,其中拖拉一个普通的日历控件即可。然后写入如下代码:
Partial Class CalendarUC_ascx
Inherits System.Web.UI.UserControl
Implements ISelectedDate
Public ReadOnly Property SelectedDate( ) As Date Implements ISelectedDate.SelectedDate
Get
Return Calendar1.SelectedDate.Date
End Get
End Property
<ConnectionProvider("SelectedDate", "SelectedDate")> _
Public Function GetSelectedDate( ) As ISelectedDate
Return Me
End Function
End Class
上面的代码,首先实现了已经声明了的IselectedDate接口,要留意的是<ConnectionProvider("SelectedDate","SelectedDate")>中的写法。由于在这个例子中,日历控件要为其他的控件提供信息,因此,该日历控件是一个provider(提供者),而另外的接收信息的控件,是consumer(消费者)。而两者为了要通信,必须要提供一个通信接入点,就象一个电插头,要找到合适的电插板一样。因此,<ConnectionProvider("SelectedDate","SelectedDate")>中的第一个参数,定义了两者的接口点,第二个参数,则是要传递给consumer的参数,本例是selectedDate。
3、接下来,我们在已经做好的google.ascx控件的代码中,编写如下代码:
Private _selectedDate As ISelectedDate
<ConnectionConsumer("SelectedDate", "SelectedDate")> _
Sub setSearchText(ByVal SearchText As ISelectedDate)
Me._selectedDate = SearchText
End Sub
Protected Sub Page_PreRender(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.PreRender
If _selectedDate IsNot Nothing Then
txtSearch.Text = _selectedDate.SelectedDate.ToShortDateString
End If
End Sub
可以看到 <ConnectionConsumer("SelectedDate", "SelectedDate")>的定义必须和provider中的定义一样。
4、再修改如下代码,将两个控件的命名变得通俗易懂
<ZoneTemplate>
<uc1:Google title="Google Search" runat="server" ID="Google1" />
<uc3:CalendarUC title="Calendar Web Part" runat="server" ID="CalendarUC1" />
</ZoneTemplate>
5、最后,为了使两者能互相通信,必须在default.aspx页中修改如下代码:
<asp:WebPartManager ID="WebPartManager1" runat="server">
<StaticConnections>
<asp:WebPartConnection ID="Connection"
ProviderID="CalendarUC1"
ProviderConnectionPointID="SelectedDate"
ConsumerID="Google1"
ConsumerConnectionPointID="SelectedDate" />
</StaticConnections>
</asp:WebPartManager>
6、在页面代码中,增加一个radiobutton,用作显示connection模式,并写入如下代码:
Case 4 : WebPartManager1.DisplayMode = WebPartManager.ConnectDisplayMode
7、运行程序,选择connect displaymode模式。再选择GOOGLESEARCH的那个webpart控件,点右上角的"conenct"按钮,此时,会显示如下图所示,提示你要选择从那个控件中得到信息,这里选择日历控件,按确定。那么,当点选日历控件的某个日期值的时候,GOOGLE SEARCH的那个文本框里,就会显示相应的日期了。
- 两个webpart控件之间进行通信
- WebPart之间如何通信
- 两个APK之间进行通信
- 两个STM32之间进行SPI通信
- 一步一步webpart-两个WebPart之间交换数据(8)
- WebPart 之间互相通信详细过程
- 两个80c51单片机之间怎样进行串行通信
- 两个frame之间通信
- 两个进程之间通信
- 两个程序之间通信
- SharePoint2010: custom webpart与PerformancePoint Service之间的通信
- 线程之间进行通信!
- 两个SWF之间的通信
- Android 两个activity之间通信
- java两个进程之间通信
- 两个应用程序之间的通信
- 两个Fragment之间怎样通信?
- 两个JFramen之间的通信
- tapi3.x 录制背景铃声
- maintenance
- javascript window 属性和方法。
- 选择意味着放弃,放弃意味着欲取
- 解当前世界金融危机&谁绑架了中国经济?转自天涯
- 两个webpart控件之间进行通信
- 在ASP中调用DLL的方法 和ASP调用ASP.NET开发的DLL
- 静态修饰符
- 串口通讯—RS-232-C详解
- 开张第一篇:porting linux2.6.16 to sep4020微处理器(东南大学自主设计的arm720T处理器)
- javascript:document对象的常用属性和方法
- jMock之Expections
- 也谈Javascript的效率,createElement和innerHTML,为innerHTML平反
- 基于linux2.6.16的nand驱动开发(一)