解决JavaFX报错缺少 JavaFX 运行时组件, 需要使用该组件来运行此应用程序

  • Post author:
  • Post category:java


解决JavaFX报错缺少 JavaFX 运行时组件, 需要使用该组件来运行此应用程序

很多 JavaFX 初学者在下载并运行老的 JavaFX 项目时,经常遇到下面这个错误。

错误: 缺少 JavaFX 运行时组件, 需要使用该组件来运行此应用程序

为什么发生这种错误呢?这需要谈及 JavaFX 的历史。在 Java 8 之后,JavaFX 从 JDK 中分离出来,然后在 Java 9 时,Java 引入了 Java 模块系统。从那之后,JavaFX 要求使用 Java 模块系统来运行 JavaFX。因此,Java 8 的时候,是没有 Java 模块系统的,而且此时 JavaFX 尚未从 JDK 中分离出来(没有分离出来意味着运行 JavaFX 项目不需要添加 JavaFX 依赖),所以很多老的 JavaFX 项目使用的是 Java 8。因此,当直接使用 Java 8 以上的环境运行没有使用 Java 模块 JavaFX 老项目时就会出现如上报错。

知道原因解决起来就很简单了。方法有很多,这里列举如下。



方法 1:使用 Java 8

直接使用 Java 8 运行 JavaFX 项目,而且这样做了之后还无需添加 JavaFX 依赖。个人是

很不建议使用这种方法

的,但是很多遇到此问题的读者只是一个刚使用 JavaFX 的新人,他们拿着从网上免费下载的代码却不知道如何运行,他们只是想先试着看看运行效果,而且他们还不清楚如何引入 JavaFX 依赖,更不擅长使用 Maven 或 Gradle。那么,可以使用这种方法。从短期来看,可以省一些事情。



方法 2:使用 Java 模块系统

使用 Java 模块系统,

建议使用这种方法

。这里不详细介绍什么 Java 模块系统以及它的语法,因为这不是本文的重点。构建 Java 模块系统只需要在顶级目录中添加一个模块声明文件

module-info.java

。如果读者不知道应该在模块声明文件中编写什么,可以使用 IntelliJ IDEA 来新建一个 JavaFX 项目,然后生成的示例项目中就会有一个简单的

module-info.java

示例。

module com.example.demo {
    requires javafx.controls;
    requires javafx.fxml;


    opens com.example.demo to javafx.fxml;
    exports com.example.demo;
}

在这里插入图片描述

在这里插入图片描述



方法 3:使用引导类

使用一种引导类来代理启动 JavaFX 应用。举个例子,现在笔者将

方法 2

中使用 IntelliJ IDEA 新建的 JavaFX 示例项目中的

module-info.java

删除。此时运行此项目应该会报前述的错误。现在,只需要编写一个引导类调用 JavaFX 入口 main 方法即可消除这个错误。

package com.example.demo;

public class JavaFXBootstrap {
    public static void main(String[] args) {
        HelloApplication.main(args);
    }
}

在这里插入图片描述

因为此处没有使用模块系统,所以 Java 运行时会为其自动生成一个匿名的模块系统。可以看到编译器提出了如下警告。

X月 XX, 202X XX:XX:XX XX com.sun.javafx.application.PlatformImpl startup
警告: Unsupported JavaFX configuration: classes were loaded from 'unnamed module @1b3d156e'



版权声明:本文为wangpaiblog原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。