用javascript自定义SharePoint文档库/列表项菜单..
时间:2009-02-06 来源:sdwjian
我们在SharePoint中自定义菜单,通常通过带CustomAction 的Feature来实现,比如隐藏一个菜单:
<HideCustomAction>
GroupId = "Text"
HideActionId = "Text"
Id = "Text"
Location = "Text">
</HideCustomAction>
自定义一个菜单:
<CustomAction
Id="Extend"
Location="Microsoft.SharePoint.Administration.ApplicationManagement"
Sequence="10"
Title="Extend or upgrade virtual server"
Description="">
<UrlAction Url="vslist.aspx?NextPage=extendvsoption.aspx&Show=NeedExtend&Show=NeedUpgrade"/>
</CustomAction>
具体知识请参考SDK或者参考网上的相关文章。
但是。。。。这种方法不是都管用的,比如我要改变文档库或者列表的ListItem的菜单中的某项或者增加删除一个菜单等等,通过这种方法是没有效果的……
data:image/s3,"s3://crabby-images/3e4e8/3e4e81e894de5878a1bcdb368e2257028f3a6b51" alt=""
这个时候,我们通过javascript来实现就非常容易了,如果您看过core.js的代码就会发现,MS已经给我们预留了自定义的接口来实现我们自己的菜单定义了,MS想的就是周到哇,嘿嘿……
core.js在路径C:\Program Files\Common Files\Microsoft Shared\web server extensions\12\TEMPLATE\LAYOUTS\下的1033[英文]或者2052[中文]下,我们找到添加文档库/列表菜单的function
data:image/s3,"s3://crabby-images/dfd6a/dfd6af43a20b890a9b5571501cf266d3f1f503e3" alt=""
data:image/s3,"s3://crabby-images/63a64/63a64f5b6d31f0b20c13220ba329f9c408bea5fd" alt=""
看到了吧我们可以自定义实现Custom_AddDocLibMenuItems(文档库) / Custom_AddListMenuItems(列表)来添加我们自己的菜单,具体做法是。。。
1)在我们的页面中加入一个WebPart-内容编辑器部件,然后修改部件属性,最好将部件设置为隐藏的:
data:image/s3,"s3://crabby-images/d66a9/d66a90e5b57762b993932b6a564fe7548969e9ad" alt=""
然后点击“源编辑器...”,输入我们的自定义javascript脚本来实现我们自己的菜单:
<script language="javascript">
function Custom_AddDocLibMenuItems(m, ctx)
data:image/s3,"s3://crabby-images/25052/25052a93f58da449adbff818cb5c8f4f36272014" alt=""
data:image/s3,"s3://crabby-images/c8805/c88058b837db9350034944c9442af1aa072d1bfc" alt=""
{
strDisplayText = "我的菜单";
var rootMenu = CASubM(m,strDisplayText,"","",500);
data:image/s3,"s3://crabby-images/7c193/7c193668da2f762e78f4bd97324e4a92fbd1964b" alt=""
strDisplayText = "我的菜单还是我的菜单";
strAction = "STSNavigate('http://www.cnblogs.com')";
strImagePath=ctx.imagesPath+"oisweb.gif";
menuOption = CAMOpt(rootMenu,strDisplayText,strAction,strImagePath);
menuOption.id = "ID_MySubMenu";
return false;
}
</script>
function里怎么个写法可以参照core.js的写法:) 最后的return false;说明继续执行系统的代码,如果return true的话。。。那整个菜单就一个你自己的菜单项啦。写完后保存,然后退出编辑模式来瞧瞧:
data:image/s3,"s3://crabby-images/49c22/49c223989c823e46ac355c5b3dae3723337fd37a" alt=""
如果要去掉某个菜单,比如WorkFlow之类,我比较笨,用了个笨方法,把他内置的AddDocLibMenuItems中的脚本copy过来,把要去掉的菜单项给注释掉,然后最后来个return true;呵呵
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
</CustomAction>
具体知识请参考SDK或者参考网上的相关文章。
但是。。。。这种方法不是都管用的,比如我要改变文档库或者列表的ListItem的菜单中的某项或者增加删除一个菜单等等,通过这种方法是没有效果的……
data:image/s3,"s3://crabby-images/3e4e8/3e4e81e894de5878a1bcdb368e2257028f3a6b51" alt=""
这个时候,我们通过javascript来实现就非常容易了,如果您看过core.js的代码就会发现,MS已经给我们预留了自定义的接口来实现我们自己的菜单定义了,MS想的就是周到哇,嘿嘿……
core.js在路径C:\Program Files\Common Files\Microsoft Shared\web server extensions\12\TEMPLATE\LAYOUTS\下的1033[英文]或者2052[中文]下,我们找到添加文档库/列表菜单的function
data:image/s3,"s3://crabby-images/dfd6a/dfd6af43a20b890a9b5571501cf266d3f1f503e3" alt=""
data:image/s3,"s3://crabby-images/63a64/63a64f5b6d31f0b20c13220ba329f9c408bea5fd" alt=""
看到了吧我们可以自定义实现Custom_AddDocLibMenuItems(文档库) / Custom_AddListMenuItems(列表)来添加我们自己的菜单,具体做法是。。。
1)在我们的页面中加入一个WebPart-内容编辑器部件,然后修改部件属性,最好将部件设置为隐藏的:
data:image/s3,"s3://crabby-images/d66a9/d66a90e5b57762b993932b6a564fe7548969e9ad" alt=""
然后点击“源编辑器...”,输入我们的自定义javascript脚本来实现我们自己的菜单:
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/25052/25052a93f58da449adbff818cb5c8f4f36272014" alt=""
data:image/s3,"s3://crabby-images/c8805/c88058b837db9350034944c9442af1aa072d1bfc" alt=""
data:image/s3,"s3://crabby-images/b066d/b066daf2acf1b052e9aaf589ff028ef977186128" alt=""
data:image/s3,"s3://crabby-images/7c193/7c193668da2f762e78f4bd97324e4a92fbd1964b" alt=""
data:image/s3,"s3://crabby-images/7c193/7c193668da2f762e78f4bd97324e4a92fbd1964b" alt=""
data:image/s3,"s3://crabby-images/7c193/7c193668da2f762e78f4bd97324e4a92fbd1964b" alt=""
data:image/s3,"s3://crabby-images/7c193/7c193668da2f762e78f4bd97324e4a92fbd1964b" alt=""
data:image/s3,"s3://crabby-images/7c193/7c193668da2f762e78f4bd97324e4a92fbd1964b" alt=""
data:image/s3,"s3://crabby-images/7c193/7c193668da2f762e78f4bd97324e4a92fbd1964b" alt=""
data:image/s3,"s3://crabby-images/7c193/7c193668da2f762e78f4bd97324e4a92fbd1964b" alt=""
data:image/s3,"s3://crabby-images/7c193/7c193668da2f762e78f4bd97324e4a92fbd1964b" alt=""
data:image/s3,"s3://crabby-images/7c193/7c193668da2f762e78f4bd97324e4a92fbd1964b" alt=""
data:image/s3,"s3://crabby-images/8835a/8835a238ab0320575abc5811d4b8230379a2a5ff" alt=""
data:image/s3,"s3://crabby-images/d2229/d22298f793e0c9f02e100c3e0e29d74319e69c58" alt=""
data:image/s3,"s3://crabby-images/49c22/49c223989c823e46ac355c5b3dae3723337fd37a" alt=""
如果要去掉某个菜单,比如WorkFlow之类,我比较笨,用了个笨方法,把他内置的AddDocLibMenuItems中的脚本copy过来,把要去掉的菜单项给注释掉,然后最后来个return true;呵呵
相关阅读 更多 +