Override the list view web part menu

简介: Sometime we need to customize the menu of a list view web part to implement our own feature.

Sometime we need to customize the menu of a list view web part to implement our own feature.

For example, dynamically change the script of new menu, update menu, etc.

What we shall do is to get the menu object and change its attribute "ClientOnClickScript" or "ClientOnClickNavigateUrl".

From Reflector, we can see the source code as follows:

[DefaultValue(""), Category("Behavior")] public string ClientOnClickScript { get { return this.m_clientOnClickScript; } set { if (value == null) { value = string.Empty; } this.m_clientOnClickScript = value; this.ViewState["ClientOnClickScript"] = value; this.m_clientOnClickNavigateUrl = null; this.ViewState["ClientOnClickNavigateUrl"] = null; this.clientOnClickUsingPostBackEvent = null; } }  

[DefaultValue(""), Category("Behavior")] public string ClientOnClickNavigateUrl { get { return this.m_clientOnClickNavigateUrl; } set { if (value == null) { value = string.Empty; } value = SPUtility.GetServerRelativeUrlFromPrefixedUrl(value); value = value.Replace("'", @"/'"); this.ClientOnClickScript = "window.location = '" + value + "';"; this.m_clientOnClickNavigateUrl = value; this.ViewState["ClientOnClickNavigateUrl"] = value; } }  

In the set method, it will change the other one. That is to say, we can select either to get our feautre done.

Primary code is below:

foreach (Microsoft.SharePoint.WebPartPages.WebPart webpart in this.WebPartManager.WebParts) { if (webpart is ListViewWebPart) { ListViewWebPart listViewWebPart = (ListViewWebPart)webpart; ViewToolBar myViewToolBar = null; foreach (Control control in listViewWebPart.Controls) { if (control is ViewToolBar) { myViewToolBar = (ViewToolBar)control; } } ToolBar myToolBar = (ToolBar)myViewToolBar.Controls[0].FindControl("toolBarTbl"); IEnumerator menus = myToolBar.Buttons.Controls.GetEnumerator(); while (menus.MoveNext()) { if (menus.Current is ActionsMenu) { } else if (menus.Current is NewMenu) { NewMenu newMenu = (menus.Current as NewMenu); MenuItemTemplate newFileMenu = newMenu.MenuTemplateControl.FindControl("New0") as MenuItemTemplate; if (newFileMenu != null) { newFileMenu.Visible = false; } MenuItemTemplate newFolderMenu = newMenu.MenuTemplateControl.FindControl("NewFolder") as MenuItemTemplate; if (newFolderMenu != null) { //newFolderMenu.ClientOnClickNavigateUrl = "/_layouts/LibraryTree/CreateFolder.aspx?mURL=" + redirectURL + "&FolderURL=" + folderPath + "&ListID=" + mListID; newFolderMenu.ClientOnClickScript = "RedirectToURL('" + redirectURL + "','" + folderPath + "','" + mListID + "')"; } } else if (menus.Current is UploadMenu) { UploadMenu uploadMenu = (menus.Current as UploadMenu); MenuItemTemplate singleUploadMenu = uploadMenu.MenuTemplateControl.FindControl("Upload") as MenuItemTemplate; if (singleUploadMenu != null) { singleUploadMenu.ClientOnClickNavigateUrl = "/_layouts/LibraryTree/UploadFile.aspx?mURL=" + redirectURL + "&FolderURL=" + folderPath + "&ListID=" + mListID; //singleUploadMenu.ClientOnClickScript = "window.location.href='/_layouts/LibraryTree/UploadFile.aspx?mURL=" + redirectURL + "&FolderURL=" + folderPath + "&ListID=" + mListID + "';"; } MenuItemTemplate multiUploadMenu = uploadMenu.MenuTemplateControl.FindControl("MultipleUpload") as MenuItemTemplate; if (multiUploadMenu != null) { multiUploadMenu.Visible = false; } } } } } 

The Microsoft doesn't suggest this way, but it is dynamic.

Hava a good time.

相关文章
|
JavaScript 前端开发 数据格式
|
1月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
112 3
|
22天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
120 45
|
3天前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
15 2
|
18天前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
32 1
|
20天前
|
XML 安全 PHP
PHP与SOAP Web服务开发:基础与进阶教程
本文介绍了PHP与SOAP Web服务的基础和进阶知识,涵盖SOAP的基本概念、PHP中的SoapServer和SoapClient类的使用方法,以及服务端和客户端的开发示例。此外,还探讨了安全性、性能优化等高级主题,帮助开发者掌握更高效的Web服务开发技巧。
|
23天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
35 2
|
1月前
|
设计模式 测试技术 持续交付
开发复杂Web应用程序
【10月更文挑战第3天】开发复杂Web应用程序
39 2
WK
|
23天前
|
安全 Java 编译器
C++和Java哪个更适合开发web网站
在Web开发领域,C++和Java各具优势。C++以其高性能、低级控制和跨平台性著称,适用于需要高吞吐量和低延迟的场景,如实时交易系统和在线游戏服务器。Java则凭借其跨平台性、丰富的生态系统和强大的安全性,广泛应用于企业级Web开发,如企业管理系统和电子商务平台。选择时需根据项目需求和技术储备综合考虑。
WK
37 0
下一篇
无影云桌面