WebPartManager 控件
Web Parts的总控中心
管理 Web Parts及区域的列表
管理页面状态 (比如显示状态),当页面状态时发生改变时触发事件
协助Web Parts间的通讯
管理个性化等
WebPart实例教程<asp:WebPartManager ID="WebPartManager1" RunAt="server" />

WebPartZone 控件
在 Web Parts页面中定义区域
定义每个区域当中Web Part的默认显示样式及布局
WebPart实例教程<asp:WebPartZone ID="WeatherZone"
WebPart实例教程DragHighlightColor
="244,198,96" RunAt="server">
WebPart实例教程
<PartTitleStyle BackColor="#2254B1" ForeColor="White" />
WebPart实例教程
<PartStyle BorderColor="#81AAF2" BorderStyle="Solid" BorderWidth="1px" />
WebPart实例教程
<ZoneTemplate>
WebPart实例教程
<!-- Web Parts declared here -->
WebPart实例教程
</ZoneTemplate>
WebPart实例教程
</asp:WebPartZone>

Web Part Chrome
标题框及Web Part的边框
通过 WebPartZone 定义其外观

Web Parts
在 WebPartZone中定义的控件
Web controls, user controls, custom controls
未实现IWebPart接口的控件将封装进GenericWebParts
增加以下属性: Title, Description, etc.

WebPart实例教程<ZoneTemplate>
WebPart实例教程
<asp:Calendar Title="Calendar" ID="Calendar1" RunAt="server" />
WebPart实例教程
<user:Weather Title="Weather" ID="Weather1" RunAt="server" />
WebPart实例教程
<custom:Search Title="Search" ID="Search1" RunAt="server" />
WebPart实例教程
</ZoneTemplate>

WebPartManager.DisplayMode
设置或者获取页面的显示模式
BrowserDisplayMode “正常的” 显示模式,无法编辑(默认)
DesignDisplayMode 允许拖拽式布局编辑
EditDisplayMode 允许编辑Web Part的外观及行为
CatalogDisplayMode 允许将Web Part添加在另外的页面上
ConnectDisplayMode 允许Web Parts之间进行通讯

DisplayMode 事件
WebPartManager.DisplayModeChanging
指示显示模式是否要发生改变
WebPartDisplayModeCancelEventArgs 获得新的显示模式并且允许控制者取消这种改变
WebPartManager.DisplayModeChanged
指示显示模式是否已经发生改变
WebPartDisplayModeEventArgs 得到原来的显示模式

其它的区域类型
WebPartZones 定义基本的页面显示内容
在任何时间均显示
其它区域允许页面可以被编辑
根据显示模式有条件得进行显示
CatalogZone 允许用户在页面上添加Web Part
EditorZone 允许用户更改Web Part的属性及布局
ConnectionsZone 允许用户建立Web Part之间的通讯

CatalogZone 控件
允许Web Part可以交互式的进行添加
包含一个或者多个 CatalogPart 控件
PageCatalogPart 显示页面上已经删除的Web Part的列表
DeclarativeCatalogPart 显示声明在 <WebPartsTemplate>中的Web Part的列表
ImportCatalogPart 允许从 .WebPart文件中导入的Web Part

声明 CatalogZone

WebPart实例教程<asp:CatalogZone ID="CatalogZone1" Runat="server">
WebPart实例教程
<ZoneTemplate>
WebPart实例教程
<asp:PageCatalogPart ID="PageCatalogPart1" Runat="server" />
WebPart实例教程
<asp:DeclarativeCatalogPart ID="DeclarativeCatalogPart1" Runat="server">
WebPart实例教程
<WebPartsTemplate>
WebPart实例教程
<!-- Declarative Web Parts go here -->
WebPart实例教程
</WebPartsTemplate>
WebPart实例教程
</asp:DeclarativeCatalogPart>
WebPart实例教程
<asp:ImportCatalogPart ID="ImportCatalogPart1" Runat="server" />
WebPart实例教程
</ZoneTemplate>
WebPart实例教程
</asp:CatalogZone>

EditorZone控件
允许交互式的对 Web parts进行更改
包含一个或者多个 EditorPart 控件
AppearanceEditorPart 提供修改标题及其它界面相关属性的UI
BehaviorEditorPart 提供修改行为属性的UI
LayoutEditorPart 提供修改Web Part的显示状态,区域及区域索引的UI
PropertyGridEditorPart 提供修改定制属性的UI
声明 EditorZone

WebPart实例教程<asp:EditorZone ID="EditorZone1" Runat="server">
WebPart实例教程
<ZoneTemplate>
WebPart实例教程
<asp:AppearanceEditorPart ID="AppearanceEditorPart1" Runat="server" />
WebPart实例教程
<asp:BehaviorEditorPart ID="BehaviorEditorPart1" Runat="server" />
WebPart实例教程
<asp:LayoutEditorPart ID="LayoutEditorPart1" Runat="server" />
WebPart实例教程
</ZoneTemplate>
WebPart实例教程
</asp:EditorZone>

PropertyGridEditorPart
允许修改自定义属性的UI
显示标记为 [WebBrowsable]的属性

WebPart实例教程string _stocks; // e.g., "MSFT,INTC,AMZN"
WebPart实例教程

WebPart实例教程[WebBrowsable]
WebPart实例教程
public string Stocks
 {
    
get 
    
set 
 }

WebPart实例教程

Web Part 通讯
Web Parts可以相互通讯
提供者发布接口
订阅者通过接口获得数据
WebPartManager 管理通讯
从提供者获得接口
向订阅者发布接口
通讯可以是静态的,也可以是动态的
ConnectionsZone 提供后期绑定的UI

通讯提供者
实现方法返回接口
方法特性 [ConnectionProvider]

WebPart实例教程[ConnectionProvider ("Zip Code""ZipCodeProvider")]
WebPart实例教程
public IZipCode GetZipCodeInterface ()
 _zip;
 }

WebPart实例教程


通讯订阅者
实现方法接收接口参数
方法特性 [ConnectionConsumer]

WebPart实例教程[ConnectionConsumer ("Zip Code""ZipCodeConsumer")]
WebPart实例教程
public void GetIZipCodeInterface (IZipCode provider)
 }



静态通讯方式
在 WebPartManager的 <StaticConnections> 元素中定义
最终用户无法修改
<asp:Connection>的实例

WebPart实例教程<asp:WebPartManager ID="WebPartManager1" Runat="server">
WebPart实例教程
<StaticConnections>
WebPart实例教程
<asp:Connection ID="ZipCodeConnection" Runat="server"
WebPart实例教程ProviderID
="Weather1" ProviderConnectionPointID="ZipCodeProvider"
WebPart实例教程ConsumerID
="News1" ConsumerConnectionPointID="ZipCodeConsumer" />
WebPart实例教程
</StaticConnections>
WebPart实例教程
</asp:WebPartManager>

ConnectionsZone 控件
提供供Web Part进行通讯的UI
最终用户,而不是开发人员创建通讯关系
<asp:ConnectionsZone ID="ConnectionsZone1"
Runat="server" />

Web Parts 个性化
Web Parts 个性化服务
自动保存相关Web Part的属性 (布局, 外观等等)
自动保存标记为 PersonalizableAttribute的定制属性
PersonalizationAdministration 类
提供个性化服务的API
Provider-based for flexible data storage
Per-User 个性化
[Personalizable] 为每位用户保存定制属性

WebPart实例教程string _stocks; // e.g., "MSFT,INTC,AMZN"
WebPart实例教程

WebPart实例教程[WebBrowsable]
WebPart实例教程[Personalizable]
WebPart实例教程
public string Stocks
 {
    
get 
    
set 
 }

WebPart实例教程
WebPart实例教程Shared Personalization
WebPart实例教程[Personalizable (PersonalizationScope.
-Shared)] persists properties on shared basis
WebPart实例教程
string _stocks; // e.g., "MSFT,INTC,AMZN"
WebPart实例教程

WebPart实例教程[WebBrowsable]
WebPart实例教程[Personalizable (PersonalizationScope.Shared)]
WebPart实例教程
public string Stocks
 {
    
get 
    
set 
 }

WebPart实例教程

个性化服务是基于Provider模式
使用 SQL Server Provider

WebPart实例教程<configuration>
WebPart实例教程
<system.web>
WebPart实例教程
<webParts>
WebPart实例教程
<personalization defaultProvider="AspNetSqlPersonalizationProvider" />
WebPart实例教程
</webParts>
WebPart实例教程
</system.web>
WebPart实例教程
</configuration>

定制Web Parts
任何控件均可以作为Web Parts来运行,但…
Controls that derive from WebPart can better leverage the Web Parts infrastructure
控件标题及其它与UI相关的属性
控件的AllowClose, AllowZoneChange, AllowMinimize, 以及其它行为属性
应用基于角色的安全特性 (授权方式)
增加自定义操作,导出Web Part以及更多..
增加自定义操作

WebPart实例教程public class MyWebPart : WebPart
 {
    
public override WebPartVerbCollection Verbs
    
{
        
get {
            EnsureChildControls ();
            WebPartVerb verb 
= new WebPartVerb (new WebPartEventHandler (OnClearResults));
            verb.Text 
= "Clear Results";
            WebPartVerb[] verbs 
= new WebPartVerb[] ;
            
return new WebPartVerbCollection (base.Verbs, verbs);
            }

    }


    
void OnClearResults (object sender, WebPartEventArgs args) 
    
      WebPart实例教程
 }
WebPart实例教程



导出Web Part
WebPart.ExportMode属性
WebPartExportMode.None (默认)
WebPartExportMode.All
WebPartExportMode.NonSensitiveData
“All” 及 “NonSensitiveData” 增加导出操作以便Web Part可以被导出
仅[Personalizable] 属性
PersonalizableAttribute.IsSensitive识别 “sensitive” 属性
导出所有属性

WebPart实例教程public class MyWebPart : WebPart
{
    
public MyWebPart ()
   
{
        ExportMode 
= WebPartExportMode.All;
    }

    WebPart实例教程
}



导出所选择的属性

WebPart实例教程public class MyWebPart : WebPart
{
    
public MyWebPart ()
    
{
        ExportMode 
= WebPartExportMode.NonSensitiveData;
    }


    
// This property will be exported
    [Personalizable (PersonalizationScope.User, false)]
    
public string ZipCode
    


    
// This one will not
    [Personalizable (PersonalizationScope.User, true)]
    
public string SocialSecurityNumber
    

    WebPart实例教程
}

WebPart实例教程

相关文章:

  • 2021-09-21
  • 2021-05-18
  • 2022-02-05
  • 2022-03-01
  • 2021-12-05
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-07-01
  • 2022-12-23
  • 2021-07-19
  • 2021-12-03
  • 2021-12-25
  • 2021-12-21
相关资源
相似解决方案