SharePoint 2010开发实例精选——通过客户端对象模型删除页面上的Web部件
下面的例子是在控制台应用程序中使用客户端对象模型,为了在控制台程序中使用ClientContext,我们需要添加两个dll引用到我们的项目中。Microsoft.SharePoint.Client.dll和Microsoft.SharePoint.Client.Runtime.dll。:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | public static void DeleteWP() { ClientContext ctx = new ClientContext( "http://sp2010u/it" ); Web oWeb = ctx.Web; File oFile = oWeb.GetFileByServerRelativeUrl( "/it/SitePages/Home.aspx" ); LimitedWebPartManager limitedWebPartManager = oFile.GetLimitedWebPartManager(PersonalizationScope.Shared); ctx.Load(limitedWebPartManager.WebParts); ctx.ExecuteQuery(); if (limitedWebPartManager.WebParts.Count == 0) throw new Exception( "未找到 web 部件" ); //获取添加到该页面上的第二个Web部件 WebPartDefinition oWebPartDef = limitedWebPartManager.WebParts[1]; //删除该webPart oWebPartDef.DeleteWebPart(); ctx.ExecuteQuery(); Console.WriteLine( "完成!" ); } |
如果是用javascript实现的话,你需要两个函数:一个用于在页面上查询该Web部件,另一个用于删除一个Web部件。下面的代码可以放在一个HTML表单Web部件中运行(直接贴在WebPart属性->源编辑器中)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | <script type= "text/ecmascript" language= "ecmascript" > var targetWeb; var clientContext; function runCode() { clientContext = new SP.ClientContext( "/it" ); targetWeb = clientContext.get_web(); var oFile = targetWeb.getFileByServerRelativeUrl( "/it/SitePages/Home.aspx" ); this .limitedWebPartManager = oFile.getLimitedWebPartManager(SP.WebParts.PersonalizationScope.shared); this .clientContext.load( this .limitedWebPartManager.get_webParts()); clientContext.executeQueryAsync(Function.createDelegate( this , this .deleteWebPart), Function.createDelegate( this , this .onFailedCallback)); } function deleteWebPart() { if ( this .limitedWebPartManager.get_webParts().get_count() == 0) { alert( "未找到 web 部件" ); return ; } //获取添加到该页面上的第二个WebPart var oWebPartDef = this .limitedWebPartManager.get_webParts().get_item(1); oWebPartDef.deleteWebPart(); this .clientContext.executeQueryAsync(Function.createDelegate( this , this .onSucceededCallback),Function.createDelegate( this , this .onFailedCallback)); } function onSucceededCallback(sender, args) { alert( "完成!" ); } function onFailedCallback(sender, args) { alert( '请求失败. \nError: ' + args.get_message() + '\nStackTrace: ' + args.get_stackTrace()); } </script> <input id= "Button1" type= "button" value= "运行代码" onclick= "runCode()" /> |
看一下网页中的运行效果:
原始页面:
在“每日一句”WebPart左侧再添加一个产品信息业务数据列表WebPart:
在根网站的某个页面上,添加了包含删除WebPart代码的HTML表单WebPart,用于删除上面页面上刚刚加的产品信息WebPart:
点击“运行代码”按钮,弹出成功消息框:
再回到原先的页面上,发现WebPart已经被删除了。
参考资料
Delete WebPart from Page Client object model SharePoint 2010
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!