首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ExtJS-4:方法'onMouseDown‘上的重写不起作用

ExtJS-4:方法'onMouseDown‘上的重写不起作用
EN

Stack Overflow用户
提问于 2018-08-06 22:33:49
回答 1查看 63关注 0票数 1

我无法覆盖Ext.util.Floating类中的函数'onmousedown‘。下面给出了示例。如果我想用'on‘前缀覆盖函数,有没有什么可遵循的模式?正在从重写的代码块调用构造函数,但“onMouseDown”仍会恢复为ext-all-debug文件。

代码语言:javascript
复制
Ext.define('Ext.util.Floating.override', {
    override: 'Ext.util.Floating',
    constructor: function(){console.log('onmousedown: This gets invoked.')},
    onMouseDown: function (e) {
        console.log('OverrideOnMouseDown');
        var focusTask = this.focusTask;

        if (this.floating && (!focusTask || !focusTask.id)) {
            this.toFront(!!e.getTarget(':focusable'));
        }
    }
});
EN

回答 1

Stack Overflow用户

发布于 2018-08-08 22:46:43

类'Ext.util.Floating‘的构造函数被硬编码为拾取方法'onMouseDown’,而不检查任何重写。

我也重写了构造函数,并实现了对'onMouseDown‘是否存在重写的检查。

代码语言:javascript
复制
Ext.define('Ext.util.Floating.override', {
    override: 'Ext.util.Floating',
    constructor: function(){
        .
        .
        .
        me.mon(me.el, {
                //redirects to the overridden method we provided.
                mousedown: me.mixins.floating.onMouseDown ? me.mixins.floating.onMouseDown: me.onMouseDown,
                scope: me
        });
        .
        .
        .
    },
    onMouseDown: function (e) {
        console.log('OverrideOnMouseDown');
        var focusTask = this.focusTask;

        if (this.floating && (!focusTask || !focusTask.id)) {
            this.toFront(!!e.getTarget(':focusable'));
        }
    } 
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51710034

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档