ImageVerifierCode 换一换
你正在下载:

WebPart.docx

[预览]
格式:DOCX , 页数:15 ,大小:296.18KB ,
资源ID:25765159      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/25765159.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(WebPart.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

WebPart.docx

1、WebPartASP.NET 2.0中使用webpart系列控件1。运行C:WINDOWSMicrosoft.NETFrameworkv2.0.50727aspnet_regsql.exe在这里进行一系列设置之后,你就会发现在数据库中多了一个aspnetdb(自定义)。2。在C:WINDOWSMicrosoft.NETFrameworkv2.0.50727CONFIGweb.config中的configuration xmlns= 就可以创建WEBPARTS了在现在的网站设计中,更强调的是用户的个性化设置,让用户可以自由的设置符合自己喜好的页面成为网站开发人员的头号难题,不过现在看来这个难题微

2、软帮我们解决了。在 2.0中新增加了一系列webpart控件,可以让用户很方便地对网页的各区域布局进行调整。在一些web应用程序中,如果用户想自定义页面布局,比如一个新闻发布系统,想让左,中,右三栏的位置进行调换的话,就可以使用webpart控件。下面,我们来看下 2.0中webpart系列控件的一些基本用法。首先,在 2005 中的工具箱中,可以找到如下图所示的webpart系列控件,有很多个,限于篇幅,本文介绍其中的一些重要的控件: 在webpart系列控件中,其中的webpartmanager控件用于统一管理各webpart控件。而webpartzone控件,则是提供了各区域划分,在这些

3、区域中,用户可以往里面放置各式各样的控件,而当运行的时候,用户可以移动的就是这些webpartzone控件所在的区域。为增强认识,我们先做个简单的例子。1、首先使用 2005 beta 2(或者RC1)新建一个web站点,2、往窗体中拖拉一个webpartmanager控件,再建一个3列1行的表格,分别往每个单元格里拖拉一个webpartzone控件,如下图: 3、往webpartzone1中拖拉放一个日历控件,并为这个日历控件选择一个合适的样式4、切换到代码视图状态,将日历控件的title属性改为:todays date。注意的是,日历控件本身没有title属性,但当一个控件加入到webpa

4、rtzone区域中去后,则该控件被自动包装为GenericWebPart类型控件,这些类型的控件有title属性。5、这时,我们可以按F5来运行该程序,运行如下图所示,可以看到,区域的右上角有最小化和关闭,恢复的按钮。 接下来,我们介绍如何在webpart系列控件中,使用用户自定义的控件。1、首先,我们为工程项目增加一个google.ascx的控件,并且在images目录下,添加google那张著名的logo图片。接着,往窗体中添加一个2*2行的表格,再往其中的一个单元格添加一个image图象控件,指定其图象为google.gif,再添加一个文本框,一个按钮,如下图所示,其中,括号内的是该控件

5、的名称:3、在btnsearch按钮的click事件中写入如下代码:Response.Write(Page.IsValid)Dim queryStr As String = HttpUtility.UrlEncode(txtSearch.Text)Response.Redirect( & queryStr)End Sub4、这时,将写好的google.ascx控件,整个拖拉到我们刚才建立好的表格中的中间那个单元格,如下图所示: 我们并且修改代码如下,修改其名称为google serach:uc1:Google title=Google Search runat=server ID=Google

6、1 /接下来,F5运行,可以看到,可以在googlesearch所在的webpart里进行google搜索了。同时,如果觉得webpart的那些关闭,恢复,最小化的按钮不大好看,还可以自定义按钮,比如在images目录下,添加下面的图片: 然后,在webpartzone1的属性中,指定如下的属性就可以了。CloseVerb.ImageUrl=Images/CloseVerb.gifEditVerb.ImageUrl=Images/EditVerb.gifMinimizeVerb.ImageUrl=Images/MinimizeVerb.gif RestoreVerb.ImageUrl=Imag

7、es/RestoreVerb.gif 使webpart动起来上面设计的webpart还没能动起来,要让webpart动起来的话,必须要将webpar设置为design display 模式。先为webpart添加下面的radiobutton选择框asp:RadioButtonList ID=rblMode runat=server AutoPostBack=Trueasp:ListItemBrowse Display Mode/asp:ListItemasp:ListItemDesign Display Mode/asp:ListItem/asp:RadioButtonList并且在code-

8、behind的代码中,写入如下代码:Protected Sub RadioButtonList1_SelectedIndexChanged(ByVal sender As Object, _ ByVal e As System.EventArgs) _ Handles rblMode.SelectedIndexChangedSelect Case rblMode.SelectedIndexCase 0 : WebPartManager1.DisplayMode =WebPartManager.BrowseDisplayModeCase 1 : WebPartManager1.DisplayMo

9、de = WebPartManager.DesignDisplayModeEnd SelectEnd Sub运行上面代码,选择design display mode,则可以象下图那样,自由拖动webpart,要注意的是,当移动各webpart的位置后,即使关掉浏览器,下次重新打开时,依然可以看到各个控件保持原来的位置。其实, 2.0是使用在aspnetdb.mdf中的一个叫aspnet_PersonalizationPerUser的表来保存数据的,表的结构如下所示:FieldValueId 928e121a-4042-4fb4-9520-21210b9b37c1PathId 7c3b5dc0-

10、04d0-48a2-bbb2-2b70286f22feUserId 9bff14df-024f-4bda-9a0a-b4a19ab9e387PageSettingsBinary dataLastUpdatedDate10/06/2005 4:44:05 AM如果想恢复各控件的原来位置,只需要将该数据表中相应的行删除掉就可以了。但有个问题是,如果使用每一个webpart的关闭按钮,则很难再将其恢复(当然删除数据表中的行,但十分麻烦)。在 2.0中,提供了另一种webpart,叫做catlogzone控件,下面介绍其用法:1、往窗体中拖拉一个catlogzone控件,如下图所视。2、往该catlo

11、gzone控件区域中,再拖放三个webpart系列的控件,分别是DeclarativeCatalogPart, PageCatalogPart, and ImportCatalogPart,如下图所示。其中,DeclarativeCatalogPart控件的作用是,显示目前页面上有哪些可以用的webpart控件;PageCatalogPart的作用是,可以让用户通过勾选的方式,选定将哪些控件添加转移到其他webpart区域中去。ImportCatalogPart则可以通过外部磁盘文件的方式,加载其他做好了的webpart部件。 3、在radiobutton区域中,修改以下代码,增添一个cata

12、log display的显示模式:asp:RadioButtonList ID=rblMode runat=server AutoPostBack=Trueasp:ListItemBrowse Display Mode/asp:ListItemasp:ListItemDesign Display Mode/asp:ListItemasp:ListItemCatalog Display Mode/asp:ListItem/asp:RadioButtonList然后,在code-behind的代码中,将代码修改为如下:Protected Sub rblMode_SelectedIndexChang

13、ed( _ByVal sender As Object, _ByVal e As System.EventArgs) _Handles rblMode.SelectedIndexChangedSelect Case rblMode.SelectedIndexCase 0 : WebPartManager1.DisplayMode = WebPartManager.BrowseDisplayModeCase 1 : WebPartManager1.DisplayMode = WebPartManager.DesignDisplayModeCase 2 : WebPartManager1.Disp

14、layMode = WebPartManager.CatalogDisplayModeEnd SelectEnd Sub4、在DeclarativeCatalogPart任务菜单上,点击右上角的智能感知按钮,然后选edit templates的链接,进入模版编辑状态,如下图:再往其中的webpartstemplate区域中拖拉一个google.ascx控件,如下图,这将允许用户在运行时,可以自由地往页面增加这样的google搜索控件。5、然后修改代码如下:ZoneTemplateasp:DeclarativeCatalogPart ID=DeclarativeCatalogPart1 runa

15、t=serverWebPartsTemplateuc1:Google title=Google Search ID=Google2 runat=server /WebPartsTemplate/asp:DeclarativeCatalogPart6、运行程序,可以看到,当选择catalog display mode时,会显示如下图所示的catalog zone,其中列出了当前可用的有哪些webpart控件,我们可以把这个google的控件加到其他的webpart区域,也可以尝试将已经存在的webpart控件关闭,然后在catalog zone区域中的控件列表中,把它们再加回到页面中去。此外,在

16、运行期间,还可以动态地修改webpart控件的外观等属性,如下:1) 往窗体中添加一个editor zone的区域控件,往其中再拖放一个appearanceEdiotrPart控件,该控件可以在运行时,让用户动态改变各webpart控件的属性。2) 我们再修改radiobutton选择框的代码如下,则加一个编辑模式:asp:RadioButtonList ID=rblMode runat=server AutoPostBack=Trueasp:ListItemBrowse Display Mode/asp:ListItemasp:ListItemDesign Display Mode/asp:

17、ListItemasp:ListItemCatalog Display Mode/asp:ListItemasp:ListItemEdit Display Mode/asp:ListItem/asp:RadioButtonList3) 修改code-behind代码如下:Protected Sub rblMode_SelectedIndexChanged(ByVal sender As Object, ByVal e As System.EventArgs) _Handles rblMode.SelectedIndexChangedSelect Case rblMode.SelectedInd

18、exCase 0 : WebPartManager1.DisplayMode = WebPartManager.BrowseDisplayModeCase 1 : WebPartManager1.DisplayMode = WebPartManager.DesignDisplayModeCase 2 : WebPartManager1.DisplayMode = WebPartManager.CatalogDisplayModeCase 3 : WebPartManager1.DisplayMode = WebPartManager.EditDisplayModeEnd SelectEnd S

19、ub4) 运行程序,选择edit display mode模式,这时,会发现每个控件的右上角,会多了一个edit的按钮,点该按钮,弹出如下图的窗体,用户可以修改每个控件的外观等属性。最后,我们看下,webpart控件之间还可以进行相互之间的通信,下面的例子中,要实现的是,在一个日历控件中点选某一个日期,会在已经做好的googlesearch的webpart控件的文本框中显示其日期,达到通信的目的,下面介绍其实现步骤:1、为了使两个webpart控件之间进行通信,必须先声明一个公共的接口。往工程项目里增加一个叫ISelectedDate.vb的类文件,放在app_code目录下,写入如下代码:I

20、mports Microsoft.VisualBasicPublic Interface ISelectedDateReadOnly Property SelectedDate( ) As DateEnd Interface这里,我们返回一个只读的日期属性selectedDate.2、再创建一个日历控件CalendarUC.ascx,其中拖拉一个普通的日历控件即可。然后写入如下代码:Partial Class CalendarUC_ascxInherits System.Web.UI.UserControlImplements ISelectedDatePublic ReadOnly Prop

21、erty SelectedDate( ) As Date Implements ISelectedDate.SelectedDateGetReturn Calendar1.SelectedDate.DateEnd GetEnd PropertyConnectionProvider(SelectedDate, SelectedDate) _Public Function GetSelectedDate( ) As ISelectedDateReturn MeEnd FunctionEnd Class上面的代码,首先实现了已经声明了的IselectedDate接口,要留意的是ConnectionP

22、rovider(SelectedDate, SelectedDate)中的写法。由于在这个例子中,日历控件要为其他的控件提供信息,因此,该日历控件是一个provider(提供者),而另外的接收信息的控件,是consumer(消费者)。而两者为了要通信,必须要提供一个通信接入点,就象一个电插头,要找到合适的电插板一样。因此,ConnectionProvider(SelectedDate, SelectedDate)中的第一个参数,定义了两者的接口点,第二个参数,则是要传递给consumer的参数,本例是selectedDate。3、接下来,我们在已经做好的google.ascx控件的代码中,编写

23、如下代码:Private _selectedDate As ISelectedDateConnectionConsumer(SelectedDate, SelectedDate) _Sub setSearchText(ByVal SearchText As ISelectedDate)Me._selectedDate = SearchTextEnd SubProtected Sub Page_PreRender(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.PreRenderIf _selectedDate Is

24、Not Nothing ThentxtSearch.Text = _selectedDate.SelectedDate.ToShortDateStringEnd IfEnd Sub可以看到 ConnectionConsumer(SelectedDate, SelectedDate)的定义必须和provider中的定义一样。4、再修改如下代码,将两个控件的命名变得通俗易懂ZoneTemplateuc1:Google title=Google Search runat=server ID=Google1 /uc3:CalendarUC title=Calendar Web Part runat=s

25、erver ID=CalendarUC1 /ZoneTemplate5、最后,为了使两者能互相通信,必须在default.aspx页中修改如下代码:asp:WebPartManager ID=WebPartManager1 runat=serverStaticConnectionsasp:WebPartConnection ID=Connection ProviderID=CalendarUC1ProviderConnectionPointID=SelectedDate ConsumerID=Google1 ConsumerConnectionPointID=SelectedDate /Sta

26、ticConnections/asp:WebPartManager6、在页面代码中,增加一个radiobutton,用作显示connection模式,并写入如下代码:Case 4 : WebPartManager1.DisplayMode = WebPartManager.ConnectDisplayMode7、运行程序,选择connect displaymode模式。再选择GOOGLE SEARCH的那个webpart控件,点右上角的conenct按钮,此时,会显示如下图所示,提示你要选择从那个控件中得到信息,这里选择日历控件,按确定。那么,当点选日历控件的某个日期值的时候,GOOGLE SEARCH的那个文本框里,就会显示相应的日期了。小结:本文主要介绍了在 2.0中,如何使用基本的webpart系列控件,以达到改变页面布局以及如何使页面的各webpart控件相互之间通信。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1