2017-10-13 15 views
3

私はそのトピックの他のスレッドを熟読しましたが、それでも私のコードは動作するようにして助けを求めることができません。ここで JSからJavaメソッドを実行することができません

はコードです:

BrowserComponent bc = new BrowserComponent(); 
    bc.setDebugMode(true); 
    bc.setPage("<html><body></body></html>", null); 
    JavascriptContext context = new JavascriptContext(bc); 
    bc.addWebEventListener("onLoad", e -> { 
     { 
      JSObject syso = (JSObject) context.get("{}"); 
      syso.set("print", new JSFunction() { 
       @Override 
       public void apply(JSObject self, Object[] args) { 
        System.out.println(StringUtils.injectArgs("{0} {1} {2} {3} {4} {5} {6} {7} {8} {9}", args)); 
       } 
      }); 
      context.set("window.syso", syso); 
     } 

     { 
      JSObject syso = (JSObject) context.get("syso"); 
      syso.call("print", "I", "am", "in", "syso"); 
     } 
    }); 

そして、ここでエラーです:

Error trying to execute js if (typeof(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1) == 'undefined'){ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1=[]};(ca_weblite_codename1_js_JavascriptContext_RETURN_VAR_call_3=(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1[0]).call(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1[1], 'print', 'I', 'am', 'in', 'syso')) 
[EDT] 0:0:0,2 - Codename One revisions: 0576ed169fa3bf9f9fe32b3ad516f3aeee60a66c 

[EDT] 0:0:0,3 - Exception: java.lang.RuntimeException - Failed to execute javascript ca_weblite_codename1_js_JavascriptContext_RETURN_VAR_call_3=(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1[0]).call(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1[1], 'print', 'I', 'am', 'in', 'syso'). The error was netscape.javascript.JSException: TypeError: 'undefined' is not a function (evaluating '(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1[0]).call(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1[1], 'print', 'I', 'am', 'in', 'syso')') 
java.lang.RuntimeException: Failed to execute javascript ca_weblite_codename1_js_JavascriptContext_RETURN_VAR_call_3=(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1[0]).call(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1[1], 'print', 'I', 'am', 'in', 'syso'). The error was netscape.javascript.JSException: TypeError: 'undefined' is not a function (evaluating '(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1[0]).call(ca_weblite_codename1_js_JavascriptContext_LOOKUP_TABLE1[1], 'print', 'I', 'am', 'in', 'syso')') 
    at com.codename1.javascript.JavascriptContext.call(JavascriptContext.java:975) 
    at com.codename1.javascript.JavascriptContext.call(JavascriptContext.java:862) 
    at com.codename1.javascript.JavascriptContext.call(JavascriptContext.java:807) 
    at com.codename1.javascript.JSObject.call(JSObject.java:960) 
    at net.etceterum.app.javascript.JSEngine.lambda$0(JSEngine.java:105) 

     //JSEngine.java:105 = syso.call("print", "I", "am", "in", "syso"); 

at net.etceterum.app.javascript.JSEngine$$Lambda$9/30625616.actionPerformed(Unknown Source) 
    at com.codename1.ui.util.EventDispatcher.fireActionSync(EventDispatcher.java:459) 
    at com.codename1.ui.util.EventDispatcher.access$100(EventDispatcher.java:45) 
    at com.codename1.ui.util.EventDispatcher$CallbackClass.run(EventDispatcher.java:95) 
    at com.codename1.ui.Display.processSerialCalls(Display.java:1114) 
    at com.codename1.ui.Display.edtLoopImpl(Display.java:1058) 
    at com.codename1.ui.Display.mainEDTLoop(Display.java:946) 
    at com.codename1.ui.RunnableWrapper.run(RunnableWrapper.java:120) 
    at com.codename1.impl.CodenameOneThread.run(CodenameOneThread.java:176) 

私が間違っているのは何?

ご協力いただきありがとうございます。

+0

スティーブがそれに答える資格があるかもしれませんが、この段階で 'syso'が定義されていないように見えます。 –

答えて

0

問題は、関数 "syso"を "print"、 "I"、 "am"、 "in"、 "syso"というパラメータで呼び出そうとしていることです。 JSでは、何をやったことは

syso.call("print", new Object[]{"I", "am", "in", "syso"}); 

に変更

syso.call("print", "I", "am", "in", "syso"); 

window.syso('print','I','am','in','syso'); 

され、それが動作します。

+0

こんにちはスティーブ、助けてくれてありがとう。それは今や円滑に実行されます。実際に起こっている事は何も見えません。 1つは、sysoがsystem.outにargsと仮定されている出力に何も表示されず、2つは実行時にSystem.out.println行で停止しません。私は本当に不思議です... – ebardet

+0

Raaaahhh ...申し訳ありません。私は自分のコードをスクランブルした。それはあなたが言ったように機能します。どうもありがとう。 – ebardet

関連する問題