壹佰网|ERP100 - 企业信息化知识门户

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 314|回复: 0

利用JS重写Cognos右键菜单

[复制链接]
发表于 2012/3/17 09:37:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。如果您注册时有任何问题请联系客服QQ: 83569622  。

您需要 登录 才可以下载或查看,没有帐号?注册

x
写了一个利用JS禁用Cognos右键菜单,下面的JS可以实现重写Cognos的右键菜单。只要将下面的代码拷到一个HTML项里即可
<!--菜单样式-->
<STYLE type=text/css>
    .cMenu {
        BORDER-RIGHT: #000000 1px solid;
        BORDER-TOP: #000000 1px solid;
        FONT-WEIGHT: normal;
        FONT-SIZE: 14px;
        VISIBILITY: hidden;
        BORDER-LEFT: #000000 1px solid;
        WIDTH: 150px;
        CURSOR: default;
        COLOR: #000000;
        LINE-HEIGHT: 20px;
        BORDER-BOTTOM: #000000 1px solid;
        FONT-FAMILY: Verdana, Arial, Helvetica, sans-serif;
        POSITION: absolute;
        BACKGROUND-COLOR: #eeeeff
    }
    .menuitems {
        PADDING-RIGHT: 5px;
        PADDING-LEFT: 5px
    }
</STYLE>
<DIV class=cMenu id="contextMenu" onmouseover=highLightMenu() onmouseout=lowLightMenu()>
    <DIV class=menuitems clickcall="alert('查看历史执行情况');">查看历史执行情况</DIV>
    <DIV class=menuitems clickcall="alert('查看批注');">查看批注</DIV>
    <DIV class=menuitems clickcall="alert('插入/修改批注');">插入/修改批注</DIV>
    <HR color=#aaaaaa size="0">
    <DIV class=menuitems clickcall="alert('关于');">关于</DIV>
</DIV>
<SCRIPT type="text/javascript">
var contextMenu = document.getElementById("contextMenu");
function getObjectName()
{
    return document.getElementById("cv.id").value;
}
function getRVContent()
{
    var objName = getObjectName();
    return  eval("document.getElementById('RVContent" + objName + "');");
}
function overWriteRightClick()//重写弹出菜单
{
    var objName = getObjectName();
    eval("oCV" + objName + ".rvMainWnd.displayContextMenu = displayContextMenu;");
}
function disableRightClick()
{
    var objName = getObjectName();
    eval("oCV" + objName + ".bCanUseCognosViewerContextMenu = false;");
}
/*菜单相关函数 start*/
function displayContextMenu(evt) {
    evt = (evt) ? evt : ((event) ? event : null);
    hideContextMenu();
    var rightedge = getRVContent().clientWidth - evt.clientX;
    var bottomedge = getRVContent().clientHeight - evt.clientY;
    if (rightedge < contextMenu.offsetWidth)
        contextMenu.style.left = getRVContent().scrollLeft + evt.clientX - contextMenu.offsetWidth - getRVContent().offsetLeft;
    else
        contextMenu.style.left = getRVContent().scrollLeft + evt.clientX - getRVContent().offsetLeft;
    if (bottomedge < contextMenu.offsetHeight)
        contextMenu.style.top = getRVContent().scrollTop + evt.clientY - contextMenu.offsetHeight - getRVContent().offsetTop;
    else
        contextMenu.style.top = getRVContent().scrollTop + evt.clientY - getRVContent().offsetTop;
    contextMenu.style.visibility = "visible";
    return false;
}
function hideContextMenu() {
    var object = event.srcElement;
    contextMenu.style.visibility = "hidden";
    if (object.className == "menuitems") {
        eval(object.clickcall);
    }
}
function highLightMenu() {
    var object = event.srcElement;
    if (object.className == "menuitems") {
        object.style.backgroundColor = "highlight";
        object.style.color = "white";
    }
}
function lowLightMenu() {
    var object = event.srcElement;
    if (object.className == "menuitems") {
        object.style.backgroundColor = "";
        object.style.color = "black";
    }
}
/*菜单相关函数 end*/
overWriteRightClick();
document.body.onclick = hideContextMenu;
</SCRIPT>
下面我来着介绍一下这段代码,前面的style和div主要是定义菜单的现实样式,其中引用样式为menuitems的div中有个clickcall属性,这个属性就是当点击此菜单项时调用的JS函数,可以将其改为自己的函数,我这里只是简单的调用了个alert。
getObjectName函数中有个cv.id的对象,之前也有人问过这个问题,“cv.id”是干什么用的?cognos报表在ReportStudio运行生成的对象和用URL请求生成的对象名称是不一样的,但是有规律可循,比如利用ReportStudio运行生成的报表中CognosViewer的对象名为oCVRS,而用URL请求生成的cognosViewer对象名为oCV_NS_,大家可以查看两次运行结果的源文件来进行比较,就比较直观了。发现前缀都一样(oCV)只是后面“RS”和“_NS_”不同,页面中很多对象都是用的此规则,而cv.id存储到正是后缀。这样就可以拼凑出当前运行模式下的对象名了。
getRVContent函数获取的是id为RVContent_NS_或RVContentRS的DIV对象,RVContent是展现用ReportStudio定义报表的内容,不包含CognosViewer工具栏和标题栏。
overWriteRightClick函数是将cognos右键调用的函数改为自己定义的函数。
disableRightClick函数已经说过了,禁用右键菜单。
displayContextMenu、hideContextMenu、highLightMenu、lowLightMenu这几个函数都是和菜单操作先关的,可以根据实际要求进行改造。
效果图如下:


更多图片 小图 大图
组图打开中,请稍候......
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|手机版|壹佰网 ERP100 ( 京ICP备19053597号-2 )

Copyright © 2005-2012 北京海之大网络技术有限责任公司 服务器托管由互联互通
手机:13911575376
网站技术点击发送消息给对方83569622   广告&合作 点击发送消息给对方27675401   点击发送消息给对方634043306   咨询及人才点击发送消息给对方138011526

GMT+8, 2025/11/30 13:36 , Processed in 0.026632 second(s), 15 queries , File On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表