• 使用ElementUI结合Vue完善主页的导航菜单和书籍管理以及后台数据分页查询


    目录

    动态树

    数据表

     案列

    书籍管理


    动态树

    动态树(Dynamic tree)是一种数据结构,它可以在树中动态地插入、删除和修改节点。与静态树不同,静态树的节点是固定的,一旦构建完成就无法再进行修改。而动态树可以在运行时根据需要进行节点的插入、删除和修改操作。

    在计算机科学中,动态树常用于解决一些与树相关的问题,如动态连通性问题、动态最小生成树问题等。动态树的设计和实现较为复杂,通常会使用一些高级数据结构和算法,如平衡二叉树、堆等。

    动态树的应用场景很广泛,例如在网络路由算法中可以使用动态树来维护网络拓扑结构,以便动态地调整路由路径;在图像处理中可以使用动态树来表示图像的层次结构,以便进行图像的快速搜索和修改等。

    数据表

    首先先创建数据表以及添加好数据

     案列

    在src/api目录下增加action.js的地址配置

    1. /**
    2. * 对后台请求的地址的封装,URL格式如下:
    3. * 模块名_实体名_操作
    4. */
    5. export default {
    6. 'SERVER': 'http://localhost:8080/ssm', //服务器
    7. 'SYSTEM_USER_DOLOGIN': '/user/userLogin', //登陆
    8. 'SYSTEM_USER_DOREG': '/userAction.action', //注册
    9. 'SYSTEM_MENUS': '/module/queryRootNode', //左侧菜单树
    10. 'getFullPath': k => { //获得请求的完整地址,用于mockjs测试时使用
    11. return this.SERVER + this[k];
    12. }
    13. }

    AppMain.vue的组件代码中修改<template>标签中的代码

    1. <template>
    2. <el-container class="main-container">
    3. <el-aside v-bind:class="asideClass">
    4. <LeftNav></LeftNav>
    5. </el-aside>
    6. <el-container>
    7. <el-header class="main-header">
    8. <TopNav></TopNav>
    9. </el-header>
    10. <el-main class="main-center">
    11. <router-view></router-view>
    12. </el-main>
    13. </el-container>
    14. </el-container>
    15. </template>

     LeftNav.vue编写组件中的代码

    1. <template>
    2. <el-menu router :default-active="$route.path" default-active="2" class="el-menu-vertical-demo" background-color="#334157" text-color="#fff"
    3. active-text-color="#ffd04b" :collapse="collapsed">
    4. <div class="logobox">
    5. <img class="logoimg" src="../assets/img/logo.png" alt="">
    6. </div>
    7. <el-submenu v-for="m in menus" :index="'idx_'+m.id" :key="'key_'+m.id">
    8. <template slot="title">
    9. <i :class="m.iocn"></i>
    10. <span>{{m.text}}</span>
    11. </template>
    12. <el-menu-item v-for="m2 in m.modules" :index="m2.url" :key="'key_'+m2.id">
    13. <i class="m2.icon"></i>
    14. <span>{{m2.text}}</span>
    15. </el-menu-item>
    16. </el-submenu>
    17. </el-menu>
    18. </template>
    19. <script>
    20. export default {
    21. data() {
    22. return {
    23. collapsed: false,
    24. menus: []
    25. }
    26. },
    27. created() {
    28. this.$root.Bus.$on('aaa', v => {
    29. this.collapsed = v;
    30. });
    31. let url = this.axios.urls.SYSTEM_MENUS;
    32. this.axios.get(url, {}).then(r => {
    33. console.log(r);
    34. this.menus = r.data.rows;
    35. }).catch(e => {
    36. })
    37. }
    38. }
    39. </script>
    40. <style>
    41. .el-menu-vertical-demo:not(.el-menu--collapse) {
    42. width: 240px;
    43. min-height: 400px;
    44. }
    45. .el-menu-vertical-demo:not(.el-menu--collapse) {
    46. border: none;
    47. text-align: left;
    48. }
    49. .el-menu-item-group__title {
    50. padding: 0px;
    51. }
    52. .el-menu-bg {
    53. background-color: #1f2d3d !important;
    54. }
    55. .el-menu {
    56. border: none;
    57. }
    58. .logobox {
    59. height: 40px;
    60. line-height: 40px;
    61. color: #9d9d9d;
    62. font-size: 20px;
    63. text-align: center;
    64. padding: 20px 0px;
    65. }
    66. .logoimg {
    67. height: 40px;
    68. }
    69. </style>

    在src/views目录中创建book文件,再在book的文件下创建以下两个组件

    AddBook.vue

    1. <template>
    2. <h1>书籍的新增</h1>
    3. </template>
    4. <script>
    5. </script>
    6. <style>
    7. </style>

     BookList.vue

    1. <template>
    2. <h1>书籍的数据</h1>
    3. </template>
    4. <script>
    5. </script>
    6. <style>
    7. </style>

    在src/router目录中的index.js下配置路径

    1. import Vue from 'vue'
    2. import Router from 'vue-router'
    3. import HelloWorld from '@/components/HelloWorld'
    4. import AppMain from '@/components/AppMain'
    5. import LeftNav from '@/components/LeftNav'
    6. import TopNav from '@/components/TopNav'
    7. import Login from '@/views/Login'
    8. import Register from '@/views/Register'
    9. import AddBook from '@/views/book/AddBook'
    10. import BookList from '@/views/booK/BookList'
    11. Vue.use(Router)
    12. export default new Router({
    13. routes: [{
    14. path: '/',
    15. name: 'Login',
    16. component: Login
    17. }, {
    18. path: '/Register',
    19. name: 'Register',
    20. component: Register
    21. }, {
    22. path: '/AppMain',
    23. name: 'AppMain',
    24. component: AppMain,
    25. children: [{
    26. path: '/LeftNav',
    27. name: 'LeftNav',
    28. component: LeftNav
    29. }, {
    30. path: '/TopNav',
    31. name: 'TopNav',
    32. component: TopNav
    33. },{
    34. path: '/book/AddBook',
    35. name: 'AddBook',
    36. component: AddBook
    37. }, {
    38. path: '/booK/BookList',
    39. name: 'BookList',
    40. component: BookList
    41. }]
    42. }]
    43. })

    效果图

    书籍管理

     BookList.vue 的组件中编写

    1. <template>
    2. <div class="Book" style="padding: 30px;">
    3. <!-- 输入框搜索 -->
    4. <el-form :inline="true" class="demo-form-inline">
    5. <el-form-item label="书籍名称 : ">
    6. <el-input v-model="bookname" placeholder="书籍名称"></el-input>
    7. </el-form-item>
    8. <el-form-item>
    9. <el-button type="primary" plain @click="onSubmit">查询</el-button>
    10. </el-form-item>
    11. </el-form>
    12. <!-- 书籍的书籍表格 -->
    13. <el-table :data="tableData" style="width: 100%">
    14. <el-table-column prop="id" label="书籍ID"></el-table-column>
    15. <el-table-column prop="bookname" label="书籍名称"></el-table-column>
    16. <el-table-column prop="price" label="书籍价格"></el-table-column>
    17. <el-table-column prop="booktype" label="书籍类型"></el-table-column>
    18. </el-table>
    19. <!-- 分页 -->
    20. <div class="block" style="padding: 20px;">
    21. <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page="page"
    22. background :page-sizes="[10, 20, 30, 40]" :page-size="rows" layout="total, sizes, prev, pager, next, jumper"
    23. :total="total">
    24. </el-pagination>
    25. </div>
    26. </div>
    27. </template>
    28. <script>
    29. export default {
    30. data() {
    31. return {
    32. bookname: '',
    33. tableData: [],
    34. rows: 10,
    35. total: 0,
    36. page: 1
    37. }
    38. },
    39. methods: {
    40. handleSizeChange(r) {
    41. //当页大小发生变化
    42. let params = {
    43. bookname: this.bookname,
    44. rows: r,
    45. page: this.page
    46. }
    47. // console.log(params)
    48. this.query(params);
    49. },
    50. handleCurrentChange(p) {
    51. //当前页码大小发生变化
    52. let params = {
    53. bookname: this.bookname,
    54. rows: this.rows,
    55. page: p
    56. }
    57. // console.log(params)
    58. this.query(params);
    59. },
    60. query(params) {
    61. //获取后台请求书籍数据的地址
    62. let url = this.axios.urls.SYSTEM_BookList;
    63. this.axios.get(url, {
    64. params: params
    65. }).then(d => {
    66. console.log(url)
    67. this.tableData = d.data.rows;
    68. this.total = d.data.total;
    69. }).catch(e => {});
    70. },
    71. onSubmit() {
    72. let params = {
    73. bookname: this.bookname
    74. }
    75. console.log(params)
    76. this.query(params);
    77. this.bookname = ''
    78. }
    79. },
    80. created() {
    81. this.query({})
    82. }
    83. }
    84. </script>
    85. <style>
    86. </style>

    查询效果

  • 相关阅读:
    一文熟悉 Go 函数
    vue markdown显示为html
    m基于中继协助的认知无线电频谱切换机制的matlab仿真分析
    ssm+vue的药店药品信息管理系统(有报告)。Javaee项目,ssm vue前后端分离项目。
    flutter vscode gradle 配置
    MCollections——15
    简单!这可能是最快速的个人博客搭建姿势!|原创
    cmka下切换使用不同版本的boost-未解决
    业务线程池阻塞分析
    ONLYOFFICE8.1版本桌面编辑器测评
  • 原文地址:https://blog.csdn.net/m0_74934282/article/details/133326786