Heim > Web-Frontend > js-Tutorial > Hauptteil

Wie Freemarker ein Baumnavigationsmenü generiert

一个新手
Freigeben: 2017-09-20 09:19:08
Original
1714 Leute haben es durchsucht

Viele Navigationsmenüs sind baumförmig, also Ebene für Ebene unterteilt. Eine solche Struktur muss sicherlich rekursiv verarbeitet werden.
Für Freemarker entspricht ein Makro einer Funktion, die eine Signatur und Parameterliste definiert.

Auf der Freemarker-Seite sollte es also so geschrieben sein:

        <#macro menuTree menus>
            <#if menus?? && menus?size gt 0>
                <#list menus as menu>
                    <tr>
                        <td>
                            <input type="checkbox" name="ids" value="${menu.id}" />
                        </td>
                        <td>
                <span title="${menu.name!}" style="margin-left: ${menu.leaf * 30}px;[#if menu.leaf == 0] color: #000000;[/#if]">
                ${menu.menuName!}
                </span>
                        </td>
                        <td>
                        ${menu.url!}
                        </td>
                        <td>
                        ${menu.permissionText!}
                        </td>
                        <td>
                        ${menu.sortNo!}
                        </td>
                        <td>
                            <a href="edit.jhtml?id=${menu.id}">[编辑]</a>
                        </td>
                    </tr>
                <#if menu.menuBeans?? && menu.menuBeans?size gt 0>
                    <@menuTree menus = menu.menuBeans/>
                </#if>
                </#list>
            </#if>
        </#macro>
        <!-- 调用宏 生成递归树 -->
    <@menuTree menus = dto />
Nach dem Login kopieren

Backend-Daten:

[
    {
        "id": 1, 
        "enable": true, 
        "remark": null, 
        "createBy": 1, 
        "createTime": 1503546411000, 
        "updateBy": 1, 
        "updateTime": 1503546415000, 
        "keyword": null, 
        "menuName": "系统管理", 
        "menuType": 1, 
        "parentId": null, 
        "iconcls": null, 
        "url": null, 
        "expand": null, 
        "sortNo": null, 
        "permission": null, 
        "moduleId": 1, 
        "parentName": null, 
        "leaf": 0, 
        "typeName": null, 
        "permissionText": null, 
        "menuBeans": [
            {
                "id": 7, 
                "enable": true, 
                "remark": null, 
                "createBy": 1, 
                "createTime": 1503546411000, 
                "updateBy": 1, 
                "updateTime": 1503546415000, 
                "keyword": null, 
                "menuName": "模块管理", 
                "menuType": 1, 
                "parentId": 1, 
                "iconcls": null, 
                "url": "/module/list", 
                "expand": null, 
                "sortNo": null, 
                "permission": null, 
                "moduleId": 1, 
                "parentName": null, 
                "leaf": 1, 
                "typeName": null, 
                "permissionText": null, 
                "menuBeans": null
            }, 
            {
                "id": 3, 
                "enable": true, 
                "remark": null, 
                "createBy": 1, 
                "createTime": 1503546411000, 
                "updateBy": 1, 
                "updateTime": 1503546415000, 
                "keyword": null, 
                "menuName": "菜单管理", 
                "menuType": 1, 
                "parentId": 1, 
                "iconcls": null, 
                "url": "/menu/list", 
                "expand": null, 
                "sortNo": null, 
                "permission": "admin:add", 
                "moduleId": 1, 
                "parentName": null, 
                "leaf": 1, 
                "typeName": null, 
                "permissionText": null, 
                "menuBeans": null
            }
        ]
    }, 
    {
        "id": 2, 
        "enable": true, 
        "remark": null, 
        "createBy": 1, 
        "createTime": 1503546411000, 
        "updateBy": 1, 
        "updateTime": 1503546415000, 
        "keyword": null, 
        "menuName": "用户管理", 
        "menuType": 1, 
        "parentId": null, 
        "iconcls": null, 
        "url": null, 
        "expand": null, 
        "sortNo": null, 
        "permission": null, 
        "moduleId": 1, 
        "parentName": null, 
        "leaf": 0, 
        "typeName": null, 
        "permissionText": null, 
        "menuBeans": [
            {
                "id": 9, 
                "enable": true, 
                "remark": null, 
                "createBy": 1, 
                "createTime": 1503546411000, 
                "updateBy": 1, 
                "updateTime": 1503546415000, 
                "keyword": null, 
                "menuName": "供应商管理", 
                "menuType": 1, 
                "parentId": 2, 
                "iconcls": null, 
                "url": null, 
                "expand": null, 
                "sortNo": null, 
                "permission": null, 
                "moduleId": 1, 
                "parentName": null, 
                "leaf": 1, 
                "typeName": null, 
                "permissionText": null, 
                "menuBeans": null
            }, 
            {
                "id": 8, 
                "enable": true, 
                "remark": null, 
                "createBy": 1, 
                "createTime": 1503546411000, 
                "updateBy": 1, 
                "updateTime": 1503546415000, 
                "keyword": null, 
                "menuName": "部门管理", 
                "menuType": 1, 
                "parentId": 2, 
                "iconcls": null, 
                "url": null, 
                "expand": null, 
                "sortNo": null, 
                "permission": null, 
                "moduleId": 1, 
                "parentName": null, 
                "leaf": 1, 
                "typeName": null, 
                "permissionText": null, 
                "menuBeans": null
            }, 
            {
                "id": 6, 
                "enable": true, 
                "remark": null, 
                "createBy": 1, 
                "createTime": 1503546411000, 
                "updateBy": 1, 
                "updateTime": 1503546415000, 
                "keyword": null, 
                "menuName": "权限管理", 
                "menuType": 1, 
                "parentId": 2, 
                "iconcls": null, 
                "url": "/user/list-6", 
                "expand": null, 
                "sortNo": null, 
                "permission": null, 
                "moduleId": 1, 
                "parentName": null, 
                "leaf": 1, 
                "typeName": null, 
                "permissionText": null, 
                "menuBeans": null
            }, 
            {
                "id": 5, 
                "enable": true, 
                "remark": null, 
                "createBy": 1, 
                "createTime": 1503546411000, 
                "updateBy": 1, 
                "updateTime": 1503546415000, 
                "keyword": null, 
                "menuName": "角色管理", 
                "menuType": 1, 
                "parentId": 2, 
                "iconcls": null, 
                "url": "/user/list-5", 
                "expand": null, 
                "sortNo": null, 
                "permission": null, 
                "moduleId": 1, 
                "parentName": null, 
                "leaf": 1, 
                "typeName": null, 
                "permissionText": null, 
                "menuBeans": null
            }, 
            {
                "id": 4, 
                "enable": true, 
                "remark": null, 
                "createBy": 1, 
                "createTime": 1503546411000, 
                "updateBy": 1, 
                "updateTime": 1503546415000, 
                "keyword": null, 
                "menuName": "分销商管理", 
                "menuType": 1, 
                "parentId": 2, 
                "iconcls": null, 
                "url": "/user/add-4", 
                "expand": null, 
                "sortNo": null, 
                "permission": null, 
                "moduleId": 1, 
                "parentName": null, 
                "leaf": 1, 
                "typeName": null, 
                "permissionText": null, 
                "menuBeans": null
            }, 
            {
                "id": 10, 
                "enable": true, 
                "remark": null, 
                "createBy": 1, 
                "createTime": 1503546411000, 
                "updateBy": 1, 
                "updateTime": 1503546415000, 
                "keyword": null, 
                "menuName": "员工管理", 
                "menuType": 1, 
                "parentId": 2, 
                "iconcls": null, 
                "url": null, 
                "expand": null, 
                "sortNo": null, 
                "permission": null, 
                "moduleId": 1, 
                "parentName": null, 
                "leaf": 1, 
                "typeName": null, 
                "permissionText": null, 
                "menuBeans": null
            }
        ]
    }
]
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie Freemarker ein Baumnavigationsmenü generiert. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage