如何解决制表符callEditCancelled回调:如何确定键码?
我正在尝试捕获触发cellEditCancelled
中的Tabulator
回调的键代码,如下所示:
var table = new Tabulator(divId,{
cellEditCancelled: function (cell) {
//cell - cell component
var col = cell.getField();
var mycode= event.which || event.keyCode; //'event' is undefined
alert("cellEditCancelled called\ncolumn: " + col + "\nkeyCode: " + mycode);
},columns: [
{ title: "Project ID",field: "Projectid",widthGrow: 1,responsive: 0,hozAlign: "center",editor: "autocomplete",editorParams: { showListOnEmpty: true,allowEmpty: false,values: window.projectIdList } },{ title: "Cust Job",field: "CustomerJobId",widthGrow: 1.25,values: window.customerJobIdList } },{ title: "Project Desc",field: "ProjectDesc",widthGrow: 1.5,values: window.projDescList } },]
});
与Tabulator
中的其他回调不同,callEditCancelled
回调显然不会公开event
对象。 (例如,cellClick
回调在其关联的函数签名中公开了一个事件对象。)
我需要区分keyCode
值,以确定如何处理callEditCancelled
事件。例如,单击Tab
键与单击Esc
键的处理方式不同。
这一定很简单。我想念什么?
非常感谢您的协助。
解决方法
事件对象未传递到此函数中,因为 取消编辑 事件不是由按键触发的,它可以由许多事物触发:
- 失去焦点
- 按键
- 鼠标事件
- 滚动
- 调整表大小
- 行更新 在单元格组件或表上调用
- cancelEdit 函数
如果您只是在谈论关键事件,那么触发取消事件实际上并不是表格,这些事件实际上是由每个编辑器单独处理的,每个编辑器都有一系列绑定来侦听焦点丢失或某些关键事件,然后可以选择不执行任何操作,触发 成功 或 取消 功能。 >
有关更多详细信息,请参见Editor Documentation
由于这些原因,没有事件对象传递到 callEditCancelled 回调中。到该函数被调用时,编辑已被取消,无法停止该操作。
如果您特别希望跟踪按键事件,则可以考虑向文档中添加一个侦听器,以侦听最后一个按键/鼠标事件并将该事件对象存储在可全局访问的变量中。然后,您可以在 callEditCancelled 回调中检查该变量,以查看最后一个事件是什么。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。