javascript - JavaScript-包含函数名称的字符串

通常,如果我有一个包含函数名称的字符串,则可以执行类似...

window[functionName](arguments);


但是,在使用“ jQuery对象”样式编程(或任何正确的术语)时,这不起作用。例如;

(function ($) {
    "use strict";
    $.test = (function () {
        var func1 = function () {
            alert("func1");
        };

        var func2 = function () {
            alert("func2");
        };

        return {
            Test: function (functionName) {
                var fn = window[functionName]; // Need to specify scope here, somehow
                if (typeof fn === 'function') {
                    fn();
                } else {
                    alert("fn() = " + fn);
                }
            }
        }

    } ());
} (jQuery));

$.test.Test("func1");
$.test.Test("func2");


理想情况下,它将显示func1,然后显示func2,但显然作用域是错误的,在这种情况下,我不确定如何指示它。

在这种情况下,如何指定要调用的函数的范围?我当然可以使用eval(),但是我正试图避免这种情况...

谢谢。

最佳答案

使用对象映射来容纳函数:

    var funcs = {
        func1: function () {
            alert("func1");
        },
        func2: function () {
            alert("func2");
        }
    };

    return {
        Test: function (functionName) {
            var fn = funcs[functionName];
            if (typeof fn === 'function') {
                fn();
            } else {
                alert("fn() = " + fn);
            }
        }
    };