0

我正在为 Trumbowyg 开发一个插件,我试图将一个函数存储在一个变量中,以便以后可以调用它,但也可以在不更改包含的 javascript 文件的情况下进行覆盖。

问题是,当我尝试调用该函数时,它没有被调用。

这是我的相关代码:

init: function (trumbowyg) {
    
    var plugins = trumbowyg.o.plugins;

    ...
    
    if(!plugins.giphycrumbs.close_modal) {
        plugins.giphycrumbs.close_modal = function() {
            console.log('close modal');
            $(plugins.giphycrumbs.modal_selector).modal('hide');
        }
    }
    
    $(document).on('click', '.add_giphy', function() {
        trumbowyg.execCmd('insertImage', $(this).attr('src'), false, true);
        
        plugins.giphycrumbs.close_modal;
        
    });
    
    // If the plugin is a button
    trumbowyg.addBtnDef('giphycrumbs', {
            //this function is handled exactly the same way except it actually works
        fn: plugins.giphycrumbs.open_modal
    });
}

在我上面的代码中,您可以看到我正在检查是否plugins.giphycrumbs.close_modal未设置,如果那是真的,我将其设置为应该关闭模式的函数。

在我的点击处理程序中.add_giphyinsertImage代码有效,但plugins.giphycrumbs.close_modal从未执行(我没有得到console.log嵌入函数的消息)

如果我做console.log(plugins.giphycrumbs.close_modal)预期的功能被放入控制台。

为什么close_modal我的代码中没有执行该函数?

4

1 回答 1

1

回答

尝试close_modal在单击处理程序中添加括号。

解释

在我看来,您似乎没有调用(调用)此函数。

在您的点击处理程序中,有这一行plugins.giphycrumbs.close_modal;

在 javascript 中,这是对giphycrumbs对象属性的引用。虽然它恰好是一个函数,但除非你在它后面使用括号(并可选地给它一些参数),否则它不会被调用。

希望有帮助!

于 2020-07-20T18:17:00.387 回答