找回密码
 立即注册

QQ登录

只需一步,快速开始

dexteryao 讲师达人认证 悬赏达人认证 SpreadJS 开发认证

超级版主

124

主题

8928

帖子

1万

积分

超级版主

Rank: 8Rank: 8

积分
13552

讲师达人悬赏达人元老葡萄SpreadJS 认证SpreadJS 高级认证微信认证勋章

dexteryao 讲师达人认证 悬赏达人认证 SpreadJS 开发认证
超级版主   /  发表于:2021-2-1 15:44  /   查看:3318  /  回复:0
本帖最后由 Derrick.Jiao 于 2021-11-19 13:39 编辑

SpreadJS 组件版设计器提供了灵活的方式添加新的功能行为,那么对于原有的功能如何重新定义行为呢?
以插入图表行为为例介绍两种重新定义方法。
点击插入ribbon中的图表icon,会弹出图表类型选择对话框,如果在弹框之前想加入一个提示,来让用户确认行为,可以通过一下两种方式完成。

1. 自定义命令,命令中调用原有插入图表命令
关于自定义命令,已有前文描述,这里不做赘述。自定义命令后,需要讲原有按钮对应命令替换为新的命令
插入图表config位置如下,原始值为"insertChart",这里需要替换为新的命令名称
GC.Spread.Sheets.Designer.DefaultConfig.ribbon[1].buttonGroups[1].commandGroup.commands[0]
在新的命令execute中,可以重新调用"insertChart"命令的execute方法弹出dialog

GC.Spread.Sheets.Designer.getCommand("insertChart").execute.call(this, designer)

2. 重写原始命令execute方法
通过js灵活的配置,可以直接重写exectue方法,重新定义行为
  1. let insertChartCommand = GC.Spread.Sheets.Designer.getCommand(GC.Spread.Sheets.Designer.CommandNames.InsertChart);
  2. if(insertChartCommand){
  3.   let oldExecute = insertChartCommand.execute;
  4.   insertChartCommand.execute = function(context, propertyName, args){

  5.     //添加confirm逻辑

  6.     oldExecute.call(this, context, propertyName, args);}}
复制代码
修改完行为后重新注册命令var config = GC.Spread.Sheets.Designer.DefaultConfig
config.commandMap[GC.Spread.Sheets.Designer.CommandNames.InsertChart] = insertChartCommand;
var designer = GC.Spread.Sheets.Designer.findControl('gc-designer-container')
designer.setConfig(config)



方法2使用简单,但是影响了原有逻辑,对于整个项目可能会有影响,方法一需要重新定义config,但是对于全局影响更小。



0 个回复

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