分享好友 前端技术首页 频道列表

Vue自定义部分页面显示导航栏功能

vue  2023-03-08 17:120

遇到的问题:

最近在用Vue+elementUI开发一个网站的前端,网站的逻辑是没有账号的用户先注册,有账号的用户直接登录,登录后才能进入网站的主页。在设计导航栏的时候,考虑到登录之前不能浏览该网站,所以需要在登录页和注册页不能出现导航栏,登录后的页面才能出现导航栏。
总结一下:
具体的需求就是有的页面显示导航栏,有的不显示,即自定义显示导航栏的页面。

解决方法:

1.先创建一个放导航栏代码的Header.vue

<template>
  <div>
    <el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal">
      <el-menu-item index="1">
        <router-link to="/homepage">
          <span>首页</span>
        </router-link>
      </el-menu-item>
      <el-menu-item index="2">
        <router-link to="/composevideo">
          <span>合成视频</span>
        </router-link>
      </el-menu-item>
      <el-menu-item index="3" disabled>
        <router-link to="/">
          <span>视频圈</span>
        </router-link>
      </el-menu-item>
      <el-menu-item index="4">
        <router-link to="/useguide">
          <span>使用指南</span>
        </router-link>
      </el-menu-item>
      <el-menu-item index="5">
        <router-link to="/personalcenter">
          <span>个人中心</span>
        </router-link>
      </el-menu-item>
    </el-menu>
  </div>
</template>

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

<style scoped>
/*由a来控制router-link*/
a {
  text-decoration: none;
  color: #000000;
  font-family: sans-serif;
  font-size: 14px;
}
</style>

2.然后在APP.vue里导入这个导航
在APP.vue中引入Header.vue,然后用route.meta.keepAlive来控制是否显示头部导航栏

<template>
  <div id="app">
    <div v-if="$route.meta.keepAlive">
      <header-nav></header-nav>
      <router-view></router-view>
    </div>
    <div v-if="!$route.meta.keepAlive">
      <router-view></router-view>
    </div>
  </div>
</template>

<script>
import header from '@/views/Header';
export default{
  components: {
    headerNav: header,
  }
}
</script>

3.修改router/下的index.js
在之前的index.js中新增meta属性,为keepAlive赋值,需要显示头部导航的赋值为true,不需要的为false。
部分代码如下:

const routes = [
  {
    path: '/',
    name: 'Login',
    component: Login,
    meta:{
      keepAlive: false
    }
  },
  {
    path: '/register',
    name: 'Register',
    component: Register,
    meta:{
      keepAlive: false
    }
  },
  {
    path: '/homepage',
    name: 'Homepage',
    component: Homepage,
    meta:{
      keepAlive: true
    }
  }
]
原文地址:https://blog.csdn.net/j_l_sheng/article/details/127174287

查看更多关于【vue】的文章

展开全文
相关推荐
反对 0
举报 0
评论 0
图文资讯
热门推荐
优选好物
更多热点专题
更多推荐文章
vue3+TS 自定义指令:长按触发绑定的函数
vue3+TS 自定义指令:长按触发绑定的函数而然间看到一个在vue2中写的长按触发事件的自定义指定,想着能不能把他copy到我的vue3项目中呢。编写自定义指令时遇到的几个难点1.自定义指令的类型在ts中写任何东西都要考虑到类型的问题,自定义指令的类型问题依然存

0评论2023-03-08326

基于ZR.VUE 前端的改造,页面刷新报错
 问题描述:前后端分离开发,分开部署. 页面刷新 直接报404 错误的解决办法提示:  先在 .env.development 中 配置 VUE_APP_BASE_API , 将 '/' 替换为 后端地址 'http://localhost:8888/'如果是对应的发布的正式环境,也要修改  .env.production 的VUE_APP_

0评论2023-03-08677

Vue3 企业级优雅实战 - 组件库框架 - 9 实现组件库 cli - 上
上文搭建了组件库 cli 的基础架子,实现了创建组件时的用户交互,但遗留了 cli/src/command/create-component.ts 中的 createNewComponent 函数,该函数要实现的功能就是上文开篇提到的 —— 创建一个组件的完整步骤。本文咱们就依次实现那些步骤。(友情提示

0评论2023-03-08947

vue-3 this概念
一、this概念官方是这样说的:在 setup()内部,this 不会是该活跃实例的引用因为 setup() 是在解析其它组件选项之前被调用的,所以 setup() 内部的 this 的行为与其它选项中的 this 完全不同这在和其它选项式 API 一起使用 setup() 时可能会导致混淆啥意思呢

0评论2023-03-08538

Vue3+TypeScript 项目中,配置 ESLint 和 Prettier
接上篇:从0搭建vite-vue3-ts项目框架:配置less+svg+pinia+vant+axios文档同步项目gitee:https://gitee.com/lixin_ajax/vue3-vite-ts-pinia-vant-less.git 一、Eslint:用于检测代码安装eslint相关依赖yarn add eslint eslint-plugin-vue @typescript-esli

0评论2023-03-08825

Vue中四种操作dom方法保姆级讲解 vue中如何操作dom
目录前言一、通过ref拿到dom的引用适用场景示例代码二、通过父容器的ref遍历拿到dom引用适用场景示例代码三、通过子组件emit传递ref适用场景示例代码四、通过:ref将dom引用放到数组中适用场景示例代码前言最近主管提出了许多优化用户体验的要求,其中很多涉及

0评论2023-03-08944

Vue状态管理工具Vuex工作原理解析 vuex五种状态
目录一、什么是vuex二、vuex的工作方式三、vuex的使用场景四、工作流程五、vuex的核心API六、应用七、vuex的工作流程一、什么是vuexVuex是vue项目的状态管理器(状态管理工具)。vue项目的状态是通过vue实例(组件)绑定的变量来体现。所以也可以说vuex是用来管理

0评论2023-03-08859

更多推荐