SharePoint 部件通过EditorPart自定义属性面板
2013-07-05 14:36
155 查看
需求:编写一个新闻展示的WebPart,要求可以分类,类别是从WebService中获取的字符串,要求可以在属性中勾选分类,显示该分类的信息,分类可能会增加。我要做的就是动态生成属性中的新闻类别,至于新闻展示就很简单了。
首先,新建一个WebPart的类,然后添加引用,添加强命名,修改输出路径到bin下,然后加到网站中,引用进去,方便查看效果。
然后,添加另一个类,EditorPart类,我们要做的,就是生成我们的控件,然后重写EditorPart的两个方法,来把类别输出到SharePoint属性面板中去。
protected override void CreateChildControls()//初始化控件
这个函数,是初始化控件的,编写方法,我们需要的控件,我这里只是需要CheckBox做勾选,还有一个Button做全选。
public override bool ApplyChanges()//保存设置
这个函数,是保存我们的变量的,但是需要把要保存的值回传到属性中去,才可以保存,也就是说EditorPart只有一个编辑功能,所以我在属性中声明了一个string类型的Test变量,用来保存。This也就是EditorPart中的参数,而生成的webpart对象,则是属性了。
public override void SyncChanges()//初始化EditorPart
这个和上面的函数,作用是相反的,也就是EditorPart读取到部件属性的函数,我读取到我的Test变量,然后通过这个变量,再初始化EditorPart的选项,使看起来EditorPart保存了设置一样。
最后,在WebPart中获得编辑界面就可以了。这个就是在部件的属性面板中,初始化EditorPart的函数了,Title也就是属性的标题了。
声明了一个Test的变量,用来保存EditorPart的值,然后Browsable设置成了false,不让用户看到。呵呵。
效果:如下图所示,新闻类别,然后可以类别全选或者取消全选。
![](http://pic002.cnblogs.com/images/2012/256729/2012062916341520.jpg)
部件展示效果:[现在是勾选那个分类,页面上显示那个分类]
![](http://pic002.cnblogs.com/images/2012/256729/2012062916342870.jpg)
*************************************************************************************
作者:霖雨 出处:http://www.cnblogs.com/jianyus 本文版权归 霖雨和博客园共有,欢迎转载,但请注明出处。
首先,新建一个WebPart的类,然后添加引用,添加强命名,修改输出路径到bin下,然后加到网站中,引用进去,方便查看效果。
然后,添加另一个类,EditorPart类,我们要做的,就是生成我们的控件,然后重写EditorPart的两个方法,来把类别输出到SharePoint属性面板中去。
protected override void CreateChildControls()//初始化控件 public override bool ApplyChanges()//保存设置 public override void SyncChanges()//初始化EditorPart |
这个函数,是初始化控件的,编写方法,我们需要的控件,我这里只是需要CheckBox做勾选,还有一个Button做全选。
protected override void CreateChildControls() { string type = GetTypeStr(); string[] type2 = type.Split(';'); typecount = type2.Length; Table table = new Table(); table.CellPadding = 0; table.CellSpacing = 0; table.Style.Add(HtmlTextWriterStyle.Height, "190px"); table.Style.Add(HtmlTextWriterStyle.Width, "200px"); TableRow row = new TableRow(); TableCell cell1 = new TableCell(); TableCell cell2 = new TableCell(); for (int i = 0; i < type2.Length; i++) { cb[i] = new CheckBox(); cb[i].Text = type2[i]; this.Controls.Add(cb[i]); row = new TableRow(); cell1 = new TableCell(); cell2 = new TableCell(); cell1.Style.Add(HtmlTextWriterStyle.TextAlign, "left"); cell1.Controls.Add(cb[i]); row.Cells.Add(cell1); table.Rows.Add(row); } btn.Click += new EventHandler(btn_Click); btn.Text = "全选"; this.Controls.Add(btn); row = new TableRow(); cell1 = new TableCell(); cell2 = new TableCell(); cell1.Style.Add(HtmlTextWriterStyle.TextAlign, "left"); cell1.Controls.Add(btn); row.Cells.Add(cell1); table.Rows.Add(row); this.Controls.Add(table); } |
这个函数,是保存我们的变量的,但是需要把要保存的值回传到属性中去,才可以保存,也就是说EditorPart只有一个编辑功能,所以我在属性中声明了一个string类型的Test变量,用来保存。This也就是EditorPart中的参数,而生成的webpart对象,则是属性了。
public override bool ApplyChanges() { this.EnsureChildControls(); MyTestWebPart webpart = this.WebPartToEdit as MyTestWebPart; if (webpart == null) return false; webpart.Test = ""; for (int i = 0; i < this.typecount; i++) { if (this.cb[i].Checked == true && this.cb[i] != null) { webpart.Test += "1;"; } else { webpart.Test += "0;"; } } return true; //throw new NotImplementedException(); } |
这个和上面的函数,作用是相反的,也就是EditorPart读取到部件属性的函数,我读取到我的Test变量,然后通过这个变量,再初始化EditorPart的选项,使看起来EditorPart保存了设置一样。
public override void SyncChanges() { EnsureChildControls(); MyTestWebPart webpart = this.WebPartToEdit as MyTestWebPart; if (webpart == null) return; string GetTest = webpart.Test; string[] GetTestGroup = GetTest.Split(';'); for (int i = 0; i < GetTestGroup.Length; i++) { if (GetTestGroup[i] == "1") { cb[i].Checked = true; } } } |
public override EditorPartCollection CreateEditorParts() { EditorPartCollection baseParts = base.CreateEditorParts(); List<EditorPart> editorParts = new List<EditorPart>(1); EditorPart part = new MyTestEditerPart(); part.ID = this.ID + "_tagValueEditor"; part.Title = "新闻类别"; editorParts.Add(part); return new EditorPartCollection(baseParts, editorParts); } |
private string _Test = ""; [Browsable(false), FriendlyName("textbox类别"), Category("设置"), Description("请输入类别"), DefaultValue(""), WebPartStorage(Storage.Shared)] public string Test { get { return _Test; } set { _Test = value; } } |
![](http://pic002.cnblogs.com/images/2012/256729/2012062916341520.jpg)
部件展示效果:[现在是勾选那个分类,页面上显示那个分类]
![](http://pic002.cnblogs.com/images/2012/256729/2012062916342870.jpg)
*************************************************************************************
作者:霖雨 出处:http://www.cnblogs.com/jianyus 本文版权归 霖雨和博客园共有,欢迎转载,但请注明出处。
相关文章推荐
- SharePoint 部件通过EditorPart自定义属性面板
- SharePoint 部件通过EditorPart自定义属性面板
- Unity3D 使用 Editor 脚本,自定义 脚本的属性面板
- sharepoint 2010 可视web部件 自定义属性 控件获取到自定义属性的值
- sharepoint中自定义webpart属性面板(Web Part Properties(ToolPart))
- android中通过自定义xml实现你需要的shape效果 xml属性配置
- 「Unity3D」(10)自定义属性面板Inspector详解
- c#通过反射获取自定义属性
- 接下来的例子演示了Flex Gumbo中如何通过自定义Skin和alpha属性,创建透明填充色TextArea。
- 自定义 SharePoint 2010 Web 部件用户界面 (Wrox)
- SharePoint 2013 WebPart属性面板配置
- spring中自定义属性编辑器CustomEditorConfigurer
- android中通过自定义xml实现你需要的shape效果 xml属性配置
- SharePoint 自定义开发chart web part
- spring中自定义属性编辑器CustomEditorConfigurer
- 处理模型——通过定义一个自定义的TypeWriter和TypeReader将多个对象存储在Tag属性中
- Unity CustomEditor 自定义编辑脚本Inspector面板
- Unity Editor 基础篇(二):自定义 Inspector 面板
- MFC无边框可缩放对话框(无需修改任何对话框属性通过资源面板)
- sharepoint 2010 如何扩展webpart自定义属性边栏字段 custom webpart properties