Spring Boot Thymeleaf:如何包含html文件

MCW:

我对Spring Boot Thymeleaf有问题。我想在Thymeleaf的另一个html文件中包含一个简单的html文件。

这是我的main.html文件:在代码段的中间,您可以看到root-div,在这里我想包含dashboard.html文件。

<!DOCTYPE HTML>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <title>Admin-Area</title>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <link href="/backend/webjars/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
    <link href="/backend/webjars/bootstrap/4.0.0/css/bootstrap.min.css" rel="stylesheet">
</head>
<body>
    <nav class="navbar navbar-dark sticky-top bg-dark flex-md-nowrap p-0 fixed-top mainnav navbar-expand-xl">
        <a class="navbar-brand col-sm-3 col-md-2 mr-0" href="../dashboard/dashboard.html">B2C-Shop</a>
        <button type="button" class="navbar-toggler navbar-toggler-right">
            <span class="navbar-toggler-icon"></span>
        </button>
    </nav>
    <div class="container-fluid">
        <div class="row">
            <main role="main" class="col-md-9 ml-sm-auto col-lg-10 pt-3 px-4">
                <div th:each="script: ${scripts}">
                    <div th:if="${script.endsWith('dashboard.html')}">
                        <div id="root" th:include="dashboard :: dashboard></div>
                    </div>
                </div>
            </main>
        </div>
    </div>

    <script src="/backend/webjars/es5-shim/4.5.9/es5-shim.min.js"></script>
    <script src="/backend/webjars/es6-shim/0.20.2/es6-shim.min.js"></script>
    <script src="/backend/webjars/jquery/3.3.1/jquery.min.js"></script>
    <script src="/backend/webjars/bootstrap/4.0.0/js/bootstrap.min.js"></script>
    <script src="/backend/webjars/modernizr/2.8.3/modernizr.min.js"></script>
    <div th:each="script: ${scripts}">
        <div th:if="${script.endsWith('.js')}">
            <script type="text/javascript" th:src="'/backend/js' + ${script}"></script>
        </div>
    </div>
</body>
</html>

这是我要包含在main.html文件中的dashboard.html文件。

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
    <div th:fragment="dashboard">
        <h1>Welcome to B2C-Admin-Area</h1>
    </div>
</html>

这是我的DashboardController.java,我在其中声明dashboarb / dashboard.html文件。return methode“ getTemplate()”引用资源文件夹中的后端文件夹。

/**
     *
     * Render dash board
     *
     * @param model the attribute model
     * @return the template file name
     */
    @RequestMapping(value = "/backend/dashboard/dashboard.html", method = RequestMethod.GET)
    public String dashboard(final Model model)
    {
        String[] script = {"/dashboard/dashboard.html"};
        model.addAttribute(SCRIPT, script);
        return getTemplate();
    }

/**
     * Gets the template file name.
     *
     * @return the template file name
     */
    protected String getTemplate()
    {
        return "backend";
    }

我的文件夹结构如下所示:

在此处输入图片说明

您有包含此文件的想法吗?

谢谢。

看起来MWC。

星系:

首先按照以下结构显示您的html文件: 在此处输入图片说明

然后创建要导入的片段:假设您将以下代码保存在template / common文件夹的面包屑文件中:

<section class="content-header" th:fragment="breadcrumbfragment">
    <ol class="breadcrumb">
        <li><a href="#"><i class="fa fa-dashboard"></i> Home</a></li>
        <li class="active">Next </li>
        <li class="active">Next to Next</li>
    </ol>
</section>

现在要导入以上片段,请使用以下行:

<section class="content-header" th:replace="common/breadcrumb::breadcrumbfragment"></section>

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章