java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java WebView桌面程序

Java使用WebView实现桌面程序的技术指南

作者:Mcband

在现代软件开发中,许多应用需要在桌面程序中嵌入 Web 页面,例如,你可能需要在 Java 桌面应用中嵌入一部分 Web 前端,或者加载一个 HTML5 界面以增强用户体验,所以本文给大家介绍了Java使用WebView实现桌面程序的技术指南,需要的朋友可以参考下

1、简述

在现代软件开发中,许多应用需要在桌面程序中嵌入 Web 页面。例如,你可能需要在 Java 桌面应用中嵌入一部分 Web 前端,或者加载一个 HTML5 界面以增强用户体验。JavaFX 提供了 WebView 组件,使开发者可以轻松地在 Java 应用程序中加载和显示 Web 页面。

本博客将介绍 JavaFX WebView 的基本用法,并提供一个完整的示例,演示如何加载网页并与 JavaScript 交互。

2、WebView 特点

WebView 是 JavaFX 提供的一个嵌入式浏览器组件,它基于 WebKit 渲染引擎,支持 HTML、CSS 和 JavaScript,适用于在 Java 应用中显示 Web 内容。它的主要特点包括:

3、搭建 WebView 示例

3.1 添加 JavaFX 依赖

如果你使用 Maven,需要在 pom.xml 文件中添加 JavaFX 依赖:

<dependencies>
    <dependency>
        <groupId>org.openjfx</groupId>
        <artifactId>javafx-controls</artifactId>
        <version>17</version>
    </dependency>
    <dependency>
        <groupId>org.openjfx</groupId>
        <artifactId>javafx-web</artifactId>
        <version>17</version>
    </dependency>
</dependencies>

3.2 编写 WebView 示例代码

下面的 Java 代码演示了如何使用 WebView 加载网页,并提供了简单的 JavaScript 交互功能。

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.layout.VBox;
import javafx.scene.web.WebEngine;
import javafx.scene.web.WebView;
import javafx.stage.Stage;

public class WebViewDemo extends Application {

    @Override
    public void start(Stage primaryStage) {
        // 创建 WebView
        WebView webView = new WebView();
        WebEngine webEngine = webView.getEngine();

        // 加载网页,可以是本地文件或在线网页
        webEngine.load("https://www.baidu.com");

        // 创建一个 JavaFX 窗口
        VBox root = new VBox(webView);
        Scene scene = new Scene(root, 800, 600);

        primaryStage.setTitle("Java WebView 示例");
        primaryStage.setScene(scene);
        primaryStage.show();
    }

    public static void main(String[] args) {
        launch(args);
    }
}

3.3 运行效果

运行上面的代码后,会弹出一个 JavaFX 窗口,并在其中加载指定的 Web 页面。

4、实现 Java 和 JavaScript 交互

4.1 在 Java 中调用 JavaScript

我们可以通过 WebEngine 执行 JavaScript 代码,例如:

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Alert;
import javafx.scene.control.Button;
import javafx.scene.layout.VBox;
import javafx.scene.web.WebEngine;
import javafx.scene.web.WebView;
import javafx.stage.Stage;

public class WebViewJavaScriptDemo extends Application {

    @Override
    public void start(Stage primaryStage) {
        WebView webView = new WebView();
        WebEngine webEngine = webView.getEngine();
        webEngine.loadContent("<html><body><h2>Java 与 JavaScript 交互</h2></body></html>");

        // 处理 JavaScript alert 弹窗
        webEngine.setOnAlert(event -> {
            Alert alert = new Alert(Alert.AlertType.INFORMATION);
            alert.setTitle("JavaScript Alert");
            alert.setHeaderText(null);
            alert.setContentText(event.getData());
            alert.showAndWait();
        });

        // 创建按钮,点击后触发 Java 调用 JavaScript
        Button button = new Button("调用 JavaScript");
        button.setOnAction(event -> webEngine.executeScript("alert('Java 调用 JavaScript!');"));


        VBox root = new VBox(webView, button);
        Scene scene = new Scene(root, 800, 600);

        primaryStage.setTitle("JavaFX WebView JavaScript 交互");
        primaryStage.setScene(scene);
        primaryStage.show();
    }

    public static void main(String[] args) {
        launch(args);
    }
}

点击按钮后,会弹出 JavaScript alert 弹窗。

4.2 在 JavaScript 中调用 Java 方法

你可以让 JavaScript 调用 Java 方法,例如:

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.layout.VBox;
import javafx.scene.web.WebEngine;
import javafx.scene.web.WebView;
import javafx.stage.Stage;
import netscape.javascript.JSObject;

public class JavaScriptToJavaDemo extends Application {
    public static class JavaBridge {
        public void showMessage(String message) {
            System.out.println("JavaScript 调用 Java: " + message);
        }
    }

    @Override
    public void start(Stage primaryStage) {
        WebView webView = new WebView();
        WebEngine webEngine = webView.getEngine();

        webEngine.load("file:///E:\\lk\\springboot-example\\lm-javafx\\src\\main\\resources\\html\\activity.html");

        // 绑定 Java 对象到 JavaScript
        JSObject window = (JSObject) webEngine.executeScript("window");
        window.setMember("javaBridge", new JavaBridge());

        VBox root = new VBox(webView);
        Scene scene = new Scene(root, 800, 600);

        primaryStage.setTitle("JavaScript 调用 Java 示例");
        primaryStage.setScene(scene);
        primaryStage.show();
    }

    public static void main(String[] args) {
        launch(args);
    }
}

在resource目录创建一个html目录,存放当前交互的html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
</head>
<body>
<h2>JavaScript 调用 Java</h2>
<button onclick="javaBridge.showMessage('Hello from JavaScript!')">点击调用 Java 方法</button>
</body>
<script>
    function callJava() {
        javaBridge.showMessage("JavaScript 触发 Java 方法!");
    }
</script>
</html>

在 HTML 页面中点击按钮后,JavaScript 会调用 Java 的 showMessage 方法,并在控制台打印消息:

JavaScript 调用 Java: Hello from JavaScript!
JavaScript 调用 Java: Hello from JavaScript!
JavaScript 调用 Java: Hello from JavaScript

5、打包为可执行文件(.exe)

可以使用 jpackage 将 JavaFX 应用打包为可执行文件(.exe):

jpackage --name WebViewApp --input . --main-jar WebViewDemo.jar --main-class WebViewDemo --type exe

这样就可以将 Java WebView 应用打包为 Windows 可执行文件。

6、总结

在本博客中,我们介绍了如何在 JavaFX 中使用 WebView 加载网页,并实现 Java 与 JavaScript 之间的交互。核心内容包括:

通过 WebView,可以轻松地在 Java 桌面应用中嵌入 Web 技术,从而结合 Web 和 Java 的优势来开发强大的桌面应用。

以上就是Java使用WebView实现桌面程序的技术指南的详细内容,更多关于Java WebView桌面程序的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文