数据库设计:

后台PHP输出所有菜单数据(index.php):

<?php
header("Access-Control-Allow-Origin:*");
header("Content-type:text/json;charset=utf-8");
error_reporting(0);
require_once ("database.php");

$sql = "select * from v_menu";
$re = excute_query($sql);
$arr=[];
while ($row = $re -> fetch_assoc()) {
    if($row["isContent"]=="0"){
        $row["isContent"]=false;
    }else{
        $row["isContent"]=true;
    }
    array_push($arr,$row);
}
echo json_encode($arr);
?>

输出结果:

[{"id":"1","name":"\u7f51\u7ad9\u9996\u9875","pId":"-1","isContent":false},

{"id":"2","name":"\u5173\u4e8e\u6211\u4eec","pId":"-1","isContent":true},

{"id":"3","name":"\u516c\u53f8\u7b80\u4ecb","pId":"2","isContent":true},

{"id":"4","name":"\u516c\u53f8\u6587\u5316","pId":"2","isContent":true},

{"id":"5","name":"\u8363\u8a89\u8d44\u8d28","pId":"2","isContent":true},

{"id":"6","name":"\u5b9e\u9a8c\u5ba4\u8ba4\u8bc1","pId":"-1","isContent":true},

{"id":"7","name":"\u5b9e\u9a8c\u5ba4\u5e03\u5c40\u5efa\u7acb","pId":"6","isContent":true},

{"id":"8","name":"\u4eea\u5668\u8bbe\u5907\u9009\u62e9","pId":"6","isContent":true},

......

]

vue文件(将数据转化为树级目录):

new Vue({
            el: "#app",
            data() {
                return {
                    data: [],//查看php文件夹下的menu.json文件
                }
            },
            created() {
                this.getAllList();
            },
            methods: {
                getAllList() {
                    axios
                        .get('http://localhost/PHP/vue.js/vue+.html+axios+php/sjlr/php/index.php')
                        .then(response => {
                            let data1 = response.data;
                            // console.log(data);
                            let tree = [];
                            for (let i = 0; i < data1.length; i++) {
                                //pId为-1的父节点
                                if (data1[i].pId == '-1') {
                                    let obj = data1[i]
                                    obj.list = []
                                    tree.push(obj)
                                    data1.splice(i, 1)
                                    i--
                                }
                            }
                            if (data1.length != 0) {
                                for (let i = 0; i < tree.length; i++) {
                                    for (let j = 0; j < data1.length; j++) {
                                        if (data1[j].pId == tree[i].id) {
                                            let obj = data1[j]
                                            obj.list = []
                                            tree[i].list.push(obj)
                                            data1.splice(j, 1)
                                            j--
                                        }
                                    }
                                }
                            }
                            this.data = tree
                        })
                        .catch(function(error) {
                            // 请求失败处理
                            console.log(error);
                        });
                },
            }
        })

data数据:

........

生成菜单导航:

<el-menu theme="dark" class="el-menu-demo" mode="horizontal" background-color="#1d5daf" text-color="#fff" active-text-color="#0e81ce">
                        <template v-for="(item,index) in data">
                            <el-submenu :index=item.id v-if="item.isContent">
                                <template slot="title">
                                    {{item.name}}
                                </template>
                                <template v-for="(menu,index) in item.list">
                                    <el-menu-item :index=menu.id>{{menu.name}}</el-menu-item>
                                </template>
                            </el-submenu>
                            <el-menu-item :index=item.id v-else>{{item.name}}</el-menu-item>
                        </template>
                    </el-menu>

vue导航菜单调用PHP后台数据的更多相关文章

  1. Vue 使用 axios post请求后台数据时 404

    今天遇到Vue 使用 axios post请求后台数据时 404 使用postman 就能获取到 网上找了大半天 终于找到了解决方法,传送门:https://www.jianshu.com/p/b10 ...

  2. vue+element级联选择器对接后台数据

    1.后台接口返回的数据肯定要和级联选择器的数据一致,所以我专门弄个model存放返回的值,如下:/** * @Auther: GGDong * @Date: 2019/4/3 10:30 */@Get ...

  3. 解决springboot+vue+mybatis中,将后台数据分页显示在前台,并且根据页码自动跳转对应页码信息

    文章目录 先看效果 1.要考虑的问题,对数据进行分页查询 2.前端和后台的交互 先看效果 1.要考虑的问题,对数据进行分页查询 mapper文件这样写 从每次开始查询的位置,到每页展示的条数, < ...

  4. vue 导航菜单默认子路由

    export default new Router({ routes: [ { path: '/', name: 'index', component: index, children: [ { pa ...

  5. vue导航菜单动态展示

    地址:https://blog.csdn.net/qq_31126175/article/details/81875468      

  6. vue如何使用excel导出后台数据

    let params = { // 请求参数 要下载Excel的id 'id':this.excelId }; //导入的接口名 api_excel_exportExcel().then(res =& ...

  7. WordPress导航菜单函数

    导航菜单是每一个WordPress主题必须的元素,如果你要制作一个WordPress主题,那就必须熟悉WordPress导航菜单注册函数 register_nav_menus() 和 导航菜单调用函数 ...

  8. 基于Vue开发的门户网站展示和后台数据管理系统

    基于Vue的前端框架有很多,这几年随着前端技术的官方应用,总有是学不完的前端知识在等着我们,一个人的精力也是有限,不可能一一掌握,不过我们学习很大程度都会靠兴趣驱动,或者目标导向,最终是可以以点破面, ...

  9. vue+element UI递归方式实现多级导航菜单

    介绍 这是一个是基于element-UI的导航菜单组件基础上,进行了二次封装的菜单组件,该组件以组件递归的方式,实现了可根据从后端接收到的json菜单数据,动态渲染多级菜单的功能. 使用方法 由于该组 ...

随机推荐

  1. Some ML Tutorials

    VAE: What-is-variational-autoencoder-vae-tutorial Variational-autoencoders-explained Building variat ...

  2. BZOJ2730 [HNOI2012]矿场搭建[点双连通分量]

    看到删去一个点,需要剩下的都和关键点连通,有端联想到找点双,因为他怎么删点都是连通的. 对于一个孤立的点双,至少要设两个关键点. 如果两个点双以一个割点连接,假设断掉这个割点,两个块至少要各设一个关键 ...

  3. json.loads 报错 json.decoder.JSONDecodeError

    json.loads报json.decoder.JSONDecodeError: Expecting property name enclosed in double quotes 出现这个错误其实只 ...

  4. SpringDatajpa 使用原生的SQL进行分组查询

    话不多说,直接上代码 dao nativeQuery = true ---> 执行原生的SQL语法,也就是说这段sql拷贝到数据库中,然后就运行. 我们期望的结果: 取值: 取值结果: 结合实际 ...

  5. eclipse找不到JadClipse问题

    版本信息: Eclipse Java EE IDE for Web Developers. Version: 2018-09 (4.9.0) 根据以往配置,放在eclipse\plugins下不生效, ...

  6. Python基础--01小项目体现的基础知识

    part1:猜拳游戏 #coding=utf-8 #当有汉语时可能编译器不认识,需要定义代码 ''' 多行注释 写这个程序是为了熟悉python的基本语法 这是第一个小例子包含简单的if判断,循环和输 ...

  7. 上下文管理器和else块

    一.if 语句之外的 else块 else 子句不仅能在 if 语句中使用,还能在for.while和try语句中使用. (1)for :仅当 for 循环运行完毕时(即 for 循环没有被break ...

  8. list深拷贝和浅拷贝

    在Python中,经常要对一个list进行复制.对于复制,自然的就有深拷贝与浅拷贝问题.深拷贝与浅拷贝的区别在于,当从原本的list复制出的list之后,修改其中的任意一个是否会对另一个造成影响,即这 ...

  9. Laravel 多态关联中利用关联表相关字段进行排序的问题

    1 目标 1.1 在 Laravel 项目的开发中,多态的需求很常见,按多态关联进行排序的需求也是必须的. 1.2 请想像,我们有一个需求,荣誉栏目多态关联一个档案模型,要求在荣誉中按档案的推荐时间进 ...

  10. HDU 3081 Marriage Match II 最大流OR二分匹配

    Marriage Match IIHDU - 3081 题目大意:每个女孩子可以和没有与她或者是她的朋友有过争吵的男孩子交男朋友,现在玩一个游戏,每一轮每个女孩子都要交一个新的男朋友,问最多可以玩多少 ...