找回密码
 立即注册

QQ登录

只需一步,快速开始

Winny

超级版主

139

主题

256

帖子

1639

积分

超级版主

Rank: 8Rank: 8

积分
1639
Winny
超级版主   /  发表于:2022-11-17 17:45  /   查看:1809  /  回复:0
SpreadJS提供了工作表上的参数spread.options.allowContextMenu=false来禁用右键菜单,但这种会同时禁用掉所有的右键菜单。在部分场景下,客户需要对表单进行操作,启用工作表区域的右键菜单。但不需要新增、删除整个工作表,这就需要禁用工作表页签处的右键菜单。
SpreadJS分为两部分,分别是组件运行时及在线表格编辑器,这两者右键菜单上有一定差异,因此在禁用的代码上也会略有差异。对于组件运行时,它的右键菜单结构下如下:
image.png558566588.png
可以看到,每个右键菜单都会有workArea这个属性,我们只需要遍历所有的右键菜单去查找对应的workArea是否包含工作表页签(sheetTab),如果workArea包含sheetTab,则去除该数组项即可,详细代码如下:
  1. // 获取当前spread的右键菜单
  2. let menuData = spread.contextMenu.menuData
  3. //删除命中菜单项
  4. for(let i=0;i<menuData.length;i++){
  5.     if(menuData[i].workArea && menuData[i].workArea.indexOf("sheetTab")!=-1){
  6.     menuData.splice(i,1)
  7.     i--
  8.     }
  9. }

复制代码
对于在线表格编辑器,它的右键菜单相关的结构如下:
image.png717151488.png
可以看到,它并没有显示区域workArea的标记。这是因为设计器中的右键菜单是根据配置信息动态处理而来。如果想修改设计器的右键菜单,需要从GC.Spread.Sheets.Designer.DefaultConfig中去更改.
image.png517568358.png
如上图所示,config中的contextMenu代表的就是右键菜单命令字符串,调用GC.Spread.Sheets.Designer.getCommand("contextMenuCut")可以得到命令的详细信息,其中visibleContex代表的就是右键菜单显示的条件。
image.png791232299.png
如果想要禁用工作表页签处的右键菜单,只需将visibleContext中包含“TabStripSelected”的数组项删除即可,详细代码如下:
  1. let config = GC.Spread.Sheets.Designer.DefaultConfig
  2. for(let i=0;i<config.contextMenu.length;i++){
  3.     if(GC.Spread.Sheets.Designer.getCommand(config.contextMenu[i]).visibleContext && GC.Spread.Sheets.Designer.getCommand(config.contextMenu[i]).visibleContext.indexOf("TabStripSelected")!=-1){
  4.         config.contextMenu.splice(i,1)
  5.         i--
  6.     }
  7. }

  8. let designer = new GC.Spread.Sheets.Designer.Designer("designer-container",config)
复制代码
查看实际效果可点击这里体验。

0 个回复

您需要登录后才可以回帖 登录 | 立即注册
返回顶部