stophin
2017-06-02 07:37
采纳率: 30%
浏览 2.1k
已采纳

Javascript EXTJS关于select和itemclick事件同步问题

我用extjs做了一个grid,添加了grid.on("select", function(){})和
grid.listeners= {itemclick: function() {}}
这两个事件,因为我要一个菜单,select事件中取不到鼠标的位置,
而itemclick可以传递e参数取到鼠标位置。
但是麻烦来了,我想对grid中没有选中的row才弹出菜单,
已经选中的row不弹出菜单,但是,同时
select事件在鼠标点击时又会默认将row选中,
这样我在itemclick中一直判断到row是选中状态一直不弹出菜单。
目前解决是在itemclick中使用record.selected=true/false
来区别有没有选中,不在select中设置record.selected,
因为select中一旦给record.selected赋值true以后itemclick又都判断都是选中状态。
但是该解决方案在grid全选按钮选中时,由于
并不会调用itemclick回调,导致虽然选中了所有rows但是record.selected还是为false
这样判断仍旧有一些不起作用。所以想要select和itemclick进行同步,让select在itemclick之后再调用。除了settimeout将select延迟一段时间以外,请问还有什么方法同步这两个事件?

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • stophin 2017-06-05 09:47
    已采纳

    哎没人,自问自答吧,用了几天时间,我发现这个问题可以反过来想,就是只要itemclick就显示菜单,
    但是在deselect回调中使用menu.hide()来阻止菜单显示
    由于菜单显示和隐藏是瞬时的,不会让人看出有任何trick。另外就是deselect在itemclick回调前的问题,这种情况只在极少数情况下发生,
    并且由于没有使用任何mark,下一次点击还是按照正常的来

    点赞 打赏 评论

相关推荐 更多相似问题