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

2025-05-12 02:50

本文主要是介绍Java使用WebView实现桌面程序的技术指南,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Java使用WebView实现桌面程序的技术指南》在现代软件开发中,许多应用需要在桌面程序中嵌入Web页面,例如,你可能需要在Java桌面应用中嵌入一部分Web前端,或者加载一个HTML5界面以增强...

1、简述

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

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

2、WebView 特点

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

  • 支持加载本地或远程 HTML 页面
  • 允许 Java 与 JavaScript 互相调用
  • 提供完整的网页渲染能力
  • 适用于 JavaFX 桌面应用

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.St编程China编程age;

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 页面。

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

4、实现 Java 和 JavaScript 交互

4.1 在 Java 中调用 JavaScript

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

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Alert;
imjsport 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\\www.chinasem.cnsrc\\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=js"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 之间的交互。核心内容包括:

  • 在 Java 中嵌入 WebView 并加载网页
  • Java 调用 JavaScript 代码
  • JavaScript 调用 Java 方法
  • 将 Java WebView 应用打包成 .exe

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

以上就是Java使用WebView实现桌面程序的技术指南的详细内容,更多关于Java WebView桌面程序的资料请关注China编程(www.chinasem.cn)其它相关文章!

这篇关于Java使用WebView实现桌面程序的技术指南的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154573

相关文章

mysql8.0.43使用InnoDB Cluster配置主从复制

《mysql8.0.43使用InnoDBCluster配置主从复制》本文主要介绍了mysql8.0.43使用InnoDBCluster配置主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录1、配置Hosts解析(所有服务器都要执行)2、安装mysql shell(所有服务器都要执行)3、

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Spring Gateway动态路由实现方案

《SpringGateway动态路由实现方案》本文主要介绍了SpringGateway动态路由实现方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前沿何为路由RouteDefinitionRouteLocator工作流程动态路由实现尾巴前沿S

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

Java高效实现PowerPoint转PDF的示例详解

《Java高效实现PowerPoint转PDF的示例详解》在日常开发或办公场景中,经常需要将PowerPoint演示文稿(PPT/PPTX)转换为PDF,本文将介绍从基础转换到高级设置的多种用法,大家... 目录为什么要将 PowerPoint 转换为 PDF安装 Spire.Presentation fo

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

SpringBoot中ResponseEntity的使用方法举例详解

《SpringBoot中ResponseEntity的使用方法举例详解》ResponseEntity是Spring的一个用于表示HTTP响应的全功能对象,它可以包含响应的状态码、头信息及响应体内容,下... 目录一、ResponseEntity概述基本特点:二、ResponseEntity的基本用法1. 创