1

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

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(),但我试图避免这种情况......

谢谢。

4

1 回答 1

4

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

    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);
            }
        }
    };
于 2013-03-28T11:06:38.433 回答