从零开始手把手Vue3+TypeScript+ElementPlus管理后台项目实战十一(整体布局04之Header及用户注销)

新增Hearder

新增 src/layout/components/PageHeader.vue

<template>
  <div class="header-cont">
    <div>
      <h1>
        <router-link to="/">
          RealWorld
        </router-link>
      </h1>
    </div>
    <div>
      <template v-if="isLoggedIn">
        <el-dropdown trigger="click" @command="handleCommand">
          <div>
            {{ userInfo.username }}
            <el-icon>
              <caret-bottom />
            </el-icon>
          </div>
          <template #dropdown>
            <el-dropdown-menu>
              <el-dropdown-item command="toPersonal">个人信息</el-dropdown-item>
              <el-dropdown-item command="toLogout">Logout</el-dropdown-item>
            </el-dropdown-menu>
          </template>
        </el-dropdown>
      </template>
    </div>
  </div>
</template>
<script setup>
import { computed } from 'vue'
import { storeToRefs } from 'pinia';
import { useUserStore } from '@/stores/user';
import { useRouter } from 'vue-router';
const userStore = useUserStore();
const { userInfo, isLoggedIn } = storeToRefs(userStore);
const { removeUser } = userStore;


const router = useRouter();
const commands = ({
  toPersonal: () => {
    console.log('toPersonal')
  },
  toLogout: () => {
    console.log('toLogout')
    removeUser();
    router.push('/register')
  }
});
function handleCommand(command) {
  commands[command] && commands[command]();
}
</script>
<style lang="scss">
.header-cont {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  height: 100%;

  a {
    color: inherit;
    text-decoration: none;
  }
  h1 {
    margin: 0;
    font-size: 20px;
  }
}
</style>

修改index.vue

1717577958923.png

修改user.ts

1717578083543.png

修改注册页面

之前删除style.css,导致注册页面样式丢失,我们再稍微美化一下。

1717578211440.png

1717578232818.png

测试验证

1717578305719.png

点击logout菜单,跳转到注册页面。

1717578337827.png

最近更新

  1. TCP协议是安全的吗?

    2024-06-13 15:48:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-13 15:48:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-13 15:48:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-13 15:48:01       20 阅读

热门阅读

  1. 深入浅出: XML HttpRequest 入门指南

    2024-06-13 15:48:01       9 阅读
  2. Release和Debug的区别?Release有什么好处?【面试】

    2024-06-13 15:48:01       8 阅读
  3. QT与VS的区别?使用QT的好处?

    2024-06-13 15:48:01       10 阅读
  4. P3842 [TJOI2007] 线段

    2024-06-13 15:48:01       9 阅读
  5. 大数据平台之权限管理

    2024-06-13 15:48:01       6 阅读
  6. 【代码】数据类型之基本数据类型

    2024-06-13 15:48:01       7 阅读
  7. 软件版本库管理工具

    2024-06-13 15:48:01       8 阅读
  8. odoo15 与odoo16的一个小更新add_sign

    2024-06-13 15:48:01       8 阅读
  9. 重温react-03

    2024-06-13 15:48:01       9 阅读