Java Nashorn:JS中的抽象类是否依赖于JS函数?

时间:2016-10-05 11:08:43

标签: javascript java nashorn

我在JS中创建一个类,然后需要能够从原始JS访问函数。在我的选项中,它有点棘手,因为函数名称只是" button_A_NUMBER"可以在0到500之间使用JavaScript。我在网页上使用JavaScript过去简单的更改,所以我不确定我是否完全离开这里。

我正在使用这个["按钮_" + interfaceID]()工作很好,直到我把它改成一个类而不是一个函数。

JS文件1



function DecodedPacketButton(index) {
    var classObject = new DecodedPacket(index, 8, this) {
        complete: function(player, args) {
            try {
                var interfaceID = args[0];
                var childID = args[1];
                var slot1 = args[2];
                var slot2 = args[3];
                classObject.callMember("button_" + interfaceID, player,
                        classObject.index(), interfaceID, childID, slot1, slot2);
            } catch (e) {
                Logger.error(e);
            }
        }
    };
    return classObject;
}

function DecodedPacket121() {
    return DecodedPacketButton(0);
}




JS文件2



DecodedPacketButton.prototype.button_182
        = function(player, index, interfaceID, childID, slot1, slot2) { }




Java类



import jdk.nashorn.api.scripting.ScriptObjectMirror;

public abstract class DecodedPacket {
    private int index;
    private int size;
    private ScriptObjectMirror mirror;

    public DecodedPacket(int index, int size, ScriptObjectMirror mirror) {
        this.index = index;
        this.size = size;
        this.mirror = mirror;
    }

    public abstract void complete(Player p, Object... args);

    public void callMember(String functionName, Object... args) {
        mirror.callMember(functionName, args);
    }

    public void call(String functionName, Object... args) {
        mirror.call(functionName, args);
    }
}




我认为电话或电话会员将是我正在寻找的,但似乎都没有做到这一点。

2 个答案:

答案 0 :(得分:0)

如果要按名称调用函数,最简单的方法是将它们放在对象文字中。

var funcs = {
  func1: function () { console.log('this is function 1') },
  func2: function () { console.log('this is function 2') }
};
                      
function callFunc(name) {
  if (funcs[name]) funcs[name]();
  else console.log('Function ' + name + ' not found.');
}
                      
callFunc('func1');
callFunc('func2');
callFunc('func3'); 

答案 1 :(得分:0)

我能够通过简单地将DecodedPacketButton作为新的DecodedPacketButton返回来使原始代码按原样运行。如果有人能够向我解释新的需求和使用它的不同之处,我会很感激。