对于JavaFX的WebEngine,如何收到javascript错误通知?

时间:2015-07-13 19:23:24

标签: javascript java svg javafx javafx-webengine

我试图在JavaFX的WebView中运行一些包含Javascript的SVG。我知道我试图运行的一些脚本有错误,我正在试图弄清楚如何将它们打印到控制台,以便我可以调试它们。我尝试过以下操作,但从未调用过WebErrorEvent:

WebEngine webEngine = browser.getEngine();
webEngine.setOnError(new EventHandler<WebErrorEvent>()
{
    @Override
    public void handle(WebErrorEvent event)
    {
        System.err.println(event);
    }
});

这是从此控件获取javascript错误反馈的正确方法吗?

1 个答案:

答案 0 :(得分:0)

setOnError侦听器仅在加载给定文档时才会出错。

解决此问题的一种方法是在调用console.log时调用Java方法。你可以通过。

来做到这一点

您的外汇申请

WebEngine engine = mainWebView.getEngine();
engine.load("http://whereever.com");

engine.getLoadWorker().stateProperty().addListener(new ChangeListener<Worker.State>() {
    @Override
    public void changed(ObservableValue<? extends Worker.State> observable, Worker.State oldValue, Worker.State newValue) {
        JSObject window = (JSObject) engine.executeScript("window");
        window.setMember("java", new Bridge());
        engine.executeScript("console.log = function(message) { java.log(message); }"); // Now where ever console.log is called in your html you will get a log in Java console
   }
});

您的Bridge类

public class Bridge {

    public void exit() {
        Platform.exit();
    }

    public void log(String text) {
        System.out.println(text);
    }

}

你的HTML

<h1>Text Page</h1>
<button onclick="java.log('This is log')">Log</button>
<button onclick="console.log('This produces the same result as above')">Console.log</button>
<button onclick="java.exit()">Exit</button>

希望这有一些帮助。