赞
踩
- <!-- 侧边栏菜单区域 -->
- <el-menu
- active-text-color="#ffd04b"
- background-color="#545c64"
- text-color="#fff">
- <!-- 一级菜单 -->
- <el-submenu index="1">
- <!-- 一级菜单模板区域 -->
- <template #title>
- <!-- 图标 -->
- <el-icon><location /></el-icon>
- <!-- 文本 -->
- <span>导航一</span>
- </template>
- <!-- 二级菜单 -->
- <el-menu-item index="1-4-1">
- <!-- 二级菜单模板区域 -->
- <template #title>
- <!-- 图标 -->
- <el-icon><document /></el-icon>
- <!-- 文本 -->
- <span>导航二</span>
- </template>
- </el-menu-item>
- </el-submenu>
- </el-menu>
注意:原本 element-plus 一级菜单官网是用el-sub-menu,但是这样好像不起作用,所以就改成了element-ui 这种el-submenu 这写法。有知道的小伙伴可以留言。
特别提醒,每开发一个页面所使用到的组件,如果是按需引用,一定要先导入对应组件,再进行功能开发
1.例如,页面使用到了一个location (位置) 的图标
2. element.js 导入
3. 重新编译后运行
啊这,奇丑无比图标。这是为何呢。
5. 哎,原来是忘记把图标组件注册了,那就去element.js 配置文件全局注册一下
6. 刷新页面看效果
7.小技巧 element-ui 和element-plus 图标使用方式有区别
- // element-ui 图标使用方式
- <i class="el-icon-edit"></i>
-
- // element-plus 使用方式
- <el-icon >
- <edit></edit>
- </el-icon>
8. 特殊图标menu引入注意事项
9.vue 3 +element-plus 项目element.js 组件命名引入 小技巧
由于组件使用的是驼峰式命名规则,那么在 element.js 导入该组件时。
需要写成,ElButton
- <template>
- <el-container class="home_container">
- <!-- 头部区域 -->
- <el-header>
- <div>
- <img src="../assets/heima.png" alt="" />
- <span>电商后台管理系统</span>
- </div>
- <el-button type="info" @click="logout">退出</el-button>
- </el-header>
- <!-- 页面主体区域 -->
- <el-container>
- <!-- 侧边栏 -->
- <el-aside width="200px">
- <!-- 侧边栏菜单区域 -->
- <el-menu
- active-text-color="#ffd04b"
- background-color="#545c64"
- text-color="#fff">
- <!-- 一级菜单 -->
- <el-submenu index="1">
- <!-- 一级菜单模板区域 -->
- <template #title>
- <el-icon><location /></el-icon>
- <span>导航一</span>
- </template>
- <!-- 二级菜单 -->
- <el-menu-item index="1-4-1">
- <template #title>
- <el-icon><document /></el-icon>
- <span>导航二</span>
- </template>
- </el-menu-item>
- </el-submenu>
- </el-menu>
- </el-aside>
- <!-- 右侧内容主体区域 -->
- <el-main>Main</el-main>
- </el-container>
- </el-container>
- </template>
- <script>
- export default {
- methods: {
- logout () {
- window.sessionStorage.clear()
- this.$router.push('/login')
- }
- }
- }
- </script>
- <style lang="less" scoped>
- .home_container {
- height: 100%;
- }
- .el-header {
- background-color: #363d40;
- // 给头部设置一下弹性布局
- display: flex;
- // 让它贴标左右对齐
- justify-content: space-between;
- // 清空图片左侧padding
- padding-left: 0;
- // 按钮居中
- align-items: center;
- // 文本颜色
- color: #fff;
- // 设置文本字体大小
- font-size: 20px;
- // 嵌套
- > div {
- // 弹性布局
- display: flex;
- // 纵向上居中对齐
- align-items: center;
- // 给文本和图片添加间距,使用类选择器
- span {
- margin-left: 15px;
- }
- }
- }
- .el-aside {
- background-color: #313743;
- }
- .el-main {
- background-color: #e9edf1;
- }
- </style>
- import {
- ElButton,
- ElForm,
- ElFormItem,
- ElInput,
- ElRow,
- ElMessage,
- ElContainer,
- ElHeader,
- ElAside,
- ElMain,
- ElMenu,
- ElSubmenu,
- ElMenuItem,
- ElIcon
- } from 'element-plus'
-
- import {
- Location,
- Menu as IconMenu
- } from '@element-plus/icons'
-
- export default (app) => {
- app.use(ElButton)
- app.use(ElForm)
- app.use(ElFormItem)
- app.use(ElInput)
- app.use(ElRow)
- app.use(ElContainer)
- app.use(ElHeader)
- app.use(ElAside)
- app.use(ElMain)
- app.use(ElMenu)
- app.use(ElSubmenu)
- app.use(ElMenuItem)
- app.use(ElIcon)
- app.component('location', Location)
- app.component('iconMenu', IconMenu)
- app.config.globalProperties.$message = ElMessage
- }
以上出自:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。