网站首页 全球最实用的IT互联网站!

人工智能P2P分享Wind搜索发布信息网站地图标签大全

当前位置:诺佳网 > 软件工程 > 后端开发 > Java >

Maven JavaFX使用SCSS样式表

时间:2025-03-14 17:39

人气:

作者:admin

标签:

导读:关于SCSS 详见此处。 原理 JavaFX本身的CSS解析器不支持SCSS,因此我们需要在编译阶段将SCSS文件编译为CSS文件,然后在JavaFX中引入CSS文件。 本文使用的编译插件是sass-cli-maven-plugin。 使用...

关于SCSS

详见此处

原理

JavaFX本身的CSS解析器不支持SCSS,因此我们需要在编译阶段将SCSS文件编译为CSS文件,然后在JavaFX中引入CSS文件。

本文使用的编译插件是sass-cli-maven-plugin

使用

POM文件设置

代码如下:

<build>
    <plugins>
        <plugin>
            <groupId>us.hebi.sass</groupId>
            <artifactId>sass-cli-maven-plugin</artifactId>
            <version>1.0.3</version>
            <configuration>
                <sassVersion>1.62.0</sassVersion>
                <args>
                    <arg>${project.basedir}/src/scss/input.scss:${project.basedir}/target/classes/css/output.css</arg>
                    <arg>--no-source-map</arg>
                    <!-- 解析后的css文件会在首行增加@charset标识,JavaFX的CSS解析器不支持该语法,因此需要使用以下命令禁用 -->
                    <arg>--no-charset</arg>
                </args>
            </configuration>
            <executions>
                <execution>
                    <id>sass-exec</id>
                    <phase>generate-resources</phase>
                    <goals>
                        <goal>run</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

代码中只需要关注一个地方:

<arg>${project.basedir}/src/scss/input.scss:${project.basedir}/target/classes/css/output.css</arg>

它的基本格式是:

<arg>项目SCSS文件路径:编译后CSS文件路径</arg>

路径写好以后即可编译查看是否有效。

引入CSS文件

编译完成后,我们只需要在项目中引入CSS文件即可,以/target/classes/css/output.css地址为例:

public class MainApplication extends Application {

    @Override
    public void start(Stage stage) throws IOException {
        FXMLLoader fxmlLoader = new FXMLLoader(MainApplication.class.getResource("/fxml/main-application.fxml"));
        Parent root = fxmlLoader.load();
        // 嵌入全局css表
        root.getStylesheets().add(Objects.requireNonNull(MainApplication.class.getResource("/css/output.css"))
                .toExternalForm());
        Scene scene = new Scene(root);
        stage.setScene(scene);
        stage.show();
    }

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

}

另外,程序开发阶段运行时可能不会触发该插件的编译,如果SCSS文件更新,可能需要先手动编译一次再运行。

如果是IDEA中也可以如下设置:

温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信