Spring Boot+Vue Element学习(二)

打开项目

引入

image.png

在Element官网复制粘贴到项目中

<template>
  <div id="app">
    <el-container style="height: 500px; border: 1px solid #eee">
      <el-aside width="200px" style="background-color: rgb(238, 241, 246)">
        <el-menu :default-openeds="['1', '3']">
          <el-submenu index="1">
            <template slot="title"><i class="el-icon-message"></i>导航一</template>
            <el-menu-item-group>
              <template slot="title">分组一</template>
              <el-menu-item index="1-1">选项1</el-menu-item>
              <el-menu-item index="1-2">选项2</el-menu-item>
            </el-menu-item-group>
            <el-menu-item-group title="分组2">
              <el-menu-item index="1-3">选项3</el-menu-item>
            </el-menu-item-group>
            <el-submenu index="1-4">
              <template slot="title">选项4</template>
              <el-menu-item index="1-4-1">选项4-1</el-menu-item>
            </el-submenu>
          </el-submenu>
          <el-submenu index="2">
            <template slot="title"><i class="el-icon-menu"></i>导航二</template>
            <el-menu-item-group>
              <template slot="title">分组一</template>
              <el-menu-item index="2-1">选项1</el-menu-item>
              <el-menu-item index="2-2">选项2</el-menu-item>
            </el-menu-item-group>
            <el-menu-item-group title="分组2">
              <el-menu-item index="2-3">选项3</el-menu-item>
            </el-menu-item-group>
            <el-submenu index="2-4">
              <template slot="title">选项4</template>
              <el-menu-item index="2-4-1">选项4-1</el-menu-item>
            </el-submenu>
          </el-submenu>
          <el-submenu index="3">
            <template slot="title"><i class="el-icon-setting"></i>导航三</template>
            <el-menu-item-group>
              <template slot="title">分组一</template>
              <el-menu-item index="3-1">选项1</el-menu-item>
              <el-menu-item index="3-2">选项2</el-menu-item>
            </el-menu-item-group>
            <el-menu-item-group title="分组2">
              <el-menu-item index="3-3">选项3</el-menu-item>
            </el-menu-item-group>
            <el-submenu index="3-4">
              <template slot="title">选项4</template>
              <el-menu-item index="3-4-1">选项4-1</el-menu-item>
            </el-submenu>
          </el-submenu>
        </el-menu>
      </el-aside>

      <el-container>
        <el-header style="text-align: right; font-size: 12px">
          <el-dropdown>
            <i class="el-icon-setting" style="margin-right: 15px"></i>
            <el-dropdown-menu slot="dropdown">
              <el-dropdown-item>查看</el-dropdown-item>
              <el-dropdown-item>新增</el-dropdown-item>
              <el-dropdown-item>删除</el-dropdown-item>
            </el-dropdown-menu>
          </el-dropdown>
          <span>王小虎</span>
        </el-header>

        <el-main>
          <el-table :data="tableData">
            <el-table-column prop="date" label="日期" width="140">
            </el-table-column>
            <el-table-column prop="name" label="姓名" width="120">
            </el-table-column>
            <el-table-column prop="address" label="地址">
            </el-table-column>
          </el-table>
        </el-main>
      </el-container>
    </el-container>
  </div>
</template>

<style>
  .el-header {
    background-color: #B3C0D1;
    color: #333;
    line-height: 60px;
  }

  .el-aside {
    color: #333;
  }
</style>

<script>
  export default {
    data() {
      const item = {
        date: '2016-05-02',
        name: '王小虎',
        address: '上海市普陀区金沙江路 1518 弄'
      };
      return {
        tableData: Array(20).fill(item)
      }
    }
  };
</script>

Vue 集成 Element UI

Element UI 后台管理系统主要的标签:

el-container:构建整个⻚⾯框架。

el-aside:构建左侧菜单。

el-menu:左侧菜单内容,常⽤属性:

1:default-openeds:默认展开的菜单,通过菜单的 index 值来关联。

 <el-menu :default-openeds="['1', '3']">
image.png

2:default-active:默认选中的菜单,通过菜单的 index 值来关联。

<el-menu :default-openeds="['1', '3']" :default-active="'1-2'">
image.png
image.png

el-submenu:可展开的菜单,常⽤属性:

index:菜单的下标,⽂本类型,不能是数值类型。
template:对应 el-submenu 的菜单名。
i:设置菜单图标,通过 class 属性实则。
el-icon-messae
el-icon-menu
el-icon-setting
el-menu-item:菜单的⼦节点,不可再展开,常⽤属性:
index:菜单的下标,⽂本类型,不能是数值类型。

<el-submenu index="1">
            <template slot="title"><i class="el-icon-message"></i>导航一</template>
            <el-menu-item-group>
              <template slot="title">分组一</template>
              <el-menu-item index="1-1">选项1</el-menu-item>
              <el-menu-item index="1-2">选项2</el-menu-item>
            </el-menu-item-group>
            <el-menu-item-group title="分组2">
              <el-menu-item index="1-3">选项3</el-menu-item>
            </el-menu-item-group>
            <el-submenu index="1-4">
              <template slot="title">选项4</template>
              <el-menu-item index="1-4-1">选项4-1</el-menu-item>
            </el-submenu>
          </el-submenu>
image.png

如果菜单还需要下级菜单

          <el-submenu index="1">
            <template slot="title"><i class="el-icon-message"></i>导航一</template>
              <el-menu-item index="1-1">选项1</el-menu-item>
              <el-menu-item index="1-2">选项2</el-menu-item>
              <el-menu-item index="1-3">选项3</el-menu-item>
            <el-submenu index="1-4">
              <template slot="title"><i class="el-icon-message"></i>选项4</template>
                <el-menu-item index="1-4-1">选项4-1</el-menu-item>
                <el-menu-item index="1-4-2">选项4-2</el-menu-item>
            </el-submenu>
          </el-submenu>
image.png

Vue router 来动态构建左侧菜单

导航1
1.⻚⾯1
2.⻚⾯2
导航2
1.⻚⾯3
2.⻚⾯4

在View首先创建页面

image.png

image.png

然后在router文件夹下的index.js配置路由

import Vue from 'vue'
import VueRouter from 'vue-router'
import PageOne from "../views/PageOne"
import PageTwo from "../views/PageTwo"
import PageThree from "../views/PageThree"
import PageFour from "../views/PageFour"
import App from "../App";
Vue.use(VueRouter)

  const routes = [
  {
    path: '/',
    name: '导航1',
    component: App,
  },
  {
      path:'/pageOne',
      name:'页面1',
      component:PageOne
  },
  {
      path:'/pageTwo',
      name:'页面2',
      component:PageTwo
  },
  {
      path:'/pageThree',
      name:'页面3',
      component:PageThree
  },
  {
      path:'/pageFour',
      name:'页面4',
      component:PageFour
  }
]

测试http://localhost:8080/pageOne

image.png

不是想要的结果怎么办?
image.png

原因因为中间黄色部分的窗口没有开所以需要开窗口。
怎么开窗口?
在App.vue主页面中加<router-view></router-view>

代码如下

image.png

image.png

如何讲页面放到我们想要放的位置?

代码如下
image.png

image.png

菜单动态读取Router中的数据

router下的index.js
const routes = [
  {
    path: '/',
    name: '导航1',
    component: App,
    child:[
      {
        path:'/pageOne',
        name:'页面1',
        component:PageOne
      },
      {
        path:'/pageTwo',
        name:'页面2',
        component:PageTwo
      }
    ]
  },
    {
      path: '/navigation',
      name: '导航2',
      component: App,
      child:[
        {
          path:'/pageThree',
          name:'页面3',
          component:PageThree
        },
        {
          path:'/pageFour',
          name:'页面4',
          component:PageFour
        }
      ]
    }
app.vue怎么动态读取
获取index.js的routes 
$router.options.routes  
image.png
 <div id="app">
   <el-container style="height: 500px; border: 1px solid #eee">
     <el-aside width="200px" style="background-color: rgb(238, 241, 246)">
<!--        <el-menu :default-openeds="['1', '3']" :default-active="'1-2'">-->
<!--          <el-submenu index="1">-->
<!--            <template slot="title"><i class="el-icon-message"></i>导航一</template>-->
<!--              <el-menu-item index="1-1">选项1</el-menu-item>-->
<!--              <el-menu-item index="1-2">选项2</el-menu-item>-->
<!--              <el-menu-item index="1-3">选项3</el-menu-item>-->
<!--            <el-submenu index="1-4">-->
<!--              <template slot="title"><i class="el-icon-message"></i>选项4</template>-->
<!--                <el-menu-item index="1-4-1">选项4-1</el-menu-item>-->
<!--                <el-menu-item index="1-4-2">选项4-2</el-menu-item>-->
<!--            </el-submenu>-->
<!--          </el-submenu>-->
<!--        </el-menu>-->
       <el-menu>
         <el-submenu v-for="(item,index) in $router.options.routes" :key="item.label" :index="index+''">
           <template slot="title"><i class="el-icon-message"></i>{{item.name}}</template>
           <el-menu-item v-for="item2 in item.children" :key="item2.label">{{item2.name}}</el-menu-item>
         </el-submenu>
       </el-menu>
     </el-aside>

index代表下标 避免展开收回是冲突 index属性是字符串

image.png

如何把右侧页面只显示页面内容不嵌套导航

新建index.vue 将导航数据存放如下

index.vue

<template>
    <el-container style="height: 500px; border: 1px solid #eee">
        <el-aside width="200px" style="background-color: rgb(238, 241, 246)">
            <!--        <el-menu :default-openeds="['1', '3']" :default-active="'1-2'">-->
            <!--          <el-submenu index="1">-->
            <!--            <template slot="title"><i class="el-icon-message"></i>导航一</template>-->
            <!--              <el-menu-item index="1-1">选项1</el-menu-item>-->
            <!--              <el-menu-item index="1-2">选项2</el-menu-item>-->
            <!--              <el-menu-item index="1-3">选项3</el-menu-item>-->
            <!--            <el-submenu index="1-4">-->
            <!--              <template slot="title"><i class="el-icon-message"></i>选项4</template>-->
            <!--                <el-menu-item index="1-4-1">选项4-1</el-menu-item>-->
            <!--                <el-menu-item index="1-4-2">选项4-2</el-menu-item>-->
            <!--            </el-submenu>-->
            <!--          </el-submenu>-->
            <!--        </el-menu>-->
            <el-menu>
                <el-submenu v-for="(item,index) in $router.options.routes" :key="item.label" :index="index+''">
                    <template slot="title"><i class="el-icon-message"></i>{{item.name}}</template>
                    <el-menu-item v-for="(item2,index2) in item.children" :key="item2.label" :index="index+'-'+index2">{{item2.name}}</el-menu-item>
                </el-submenu>
            </el-menu>
        </el-aside>

        <el-main>
            <router-view></router-view>
        </el-main>
    </el-container>
</template>

<script>
    export default {
        name: "index"
    }
</script>

<style scoped>

</style>

App.vue

<template>
  <div id="app">
      <el-container>
          <el-header style="text-align: right; font-size: 12px">
              <el-dropdown>
                  <i class="el-icon-setting" style="margin-right: 15px"></i>
                  <el-dropdown-menu slot="dropdown">
                      <el-dropdown-item>查看</el-dropdown-item>
                      <el-dropdown-item>新增</el-dropdown-item>
                      <el-dropdown-item>删除</el-dropdown-item>
                  </el-dropdown-menu>
              </el-dropdown>
              <span>王小虎</span>
          </el-header>

          <el-main>
              <router-view></router-view>
          </el-main>
      </el-container>
<!--      <router-view></router-view>-->
  </div>
</template>

<style>
  .el-header {
    background-color: #B3C0D1;
    color: #333;
    line-height: 60px;
  }

  .el-aside {
    color: #333;
  }
</style>

<script>
  export default {
    data() {
      const item = {
        date: '2016-05-02',
        name: '王小虎',
        address: '上海市普陀区金沙江路 1518 弄'
      };
      return {
        tableData: Array(20).fill(item)
      }
    }
  };
</script>

index.js

import Vue from 'vue'
import VueRouter from 'vue-router'
import PageOne from "../views/PageOne"
import PageTwo from "../views/PageTwo"
import PageThree from "../views/PageThree"
import PageFour from "../views/PageFour"
// import App from "../App";
import index from "../views/index"
Vue.use(VueRouter)

  const routes = [
  {
    path: '/',
    name: '导航1',
    component: index,
    children:[
      {
        path:'/pageOne',
        name:'页面1',
        component:PageOne
      },
      {
        path:'/pageTwo',
        name:'页面2',
        component:PageTwo
      }
    ]
  },
    {
      path: '/navigation',
      name: '导航2',
      component: index,
      children:[
        {
          path:'/pageThree',
          name:'页面3',
          component:PageThree
        },
        {
          path:'/pageFour',
          name:'页面4',
          component:PageFour
        }
      ]
    }

]

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes
})

export default router

image.png

menu 与 router 的绑定

1、 标签添加 router 属性。
2、在⻚⾯中添加 标签,它是⼀个容器,动态渲染你选择的 router。
3、 标签的 index 值就是要跳转的 router。

初始化初始页面

redirect:"/pageOne",
默认跳转

path: '/',
    name: '导航1',
    component: index,
    redirect:"/pageOne",
    children:[
      {
        path:'/pageOne',
        name:'页面1',
        component:PageOne
      },

初始化没有被选中导航怎么办?

:class动态加样式

  <el-menu-item v-for="(item2) in item.children" :key="item2.label" :index="item2.path"
                    :class="$route.path==item2.path?'is-active':''">{{item2.name}}</el-menu-item>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269