Vue页面手动刷新,实现导航栏激活项还原到初始状
网络编程 2021-07-04 14:06www.168986.cn编程入门
这篇文章主要介绍了Vue页面手动刷新,实现导航栏激活项还原到初始状态,具有很好的参考价值,希望对大家有所帮助。一起跟随长沙网络推广过来看看吧
场景描述在页面中存在顶部导航和左侧导航,左侧导航和右侧内容区使用了命名视图实现,点击左侧导航的链接时,右侧内容区相应显示不同组件内容。问题在当前链接手动刷新浏览器(例如浏览器地址为/enterprise/list),顶部导航激活项还原到初始状态(这里默认是“工作台”项)。
原理每次刷新都会重新实例化Vue,也就是会调用created方法。
<template> <el-menu :default-active="defaultActiveIndex" class="el-menu-demo" mode="horizontal" @select="handleSelect" :router="true"> <el-menu-item index="/">工作台</el-menu-item> <el-menu-item index="/enterpriseManager">企业管理</el-menu-item> <el-menu-item index="/orderManager">订单管理</el-menu-item> <el-menu-item index="/systemManager">系统管理</el-menu-item> </el-menu> </template> <script> export default { name: 'app', data () { return { defaultActiveIndex: "/" } }, created() { // 组件创建完后获取数据, // 此时 data 已经被 observed 了 this.fetchData() }, methods: { handleSelect(index){ this.defaultActiveIndex = index; }, jumpTo(url){ this.defaultActiveIndex = url; this.$router.push(url); //用go刷新 }, fetchData () { var cur_path = this.$route.path; //获取当前路由 var routers = this.$router.options.routes; // 获取路由对象 var nav_type = ""; for(var i=0; i<routers.length; i++){ var children = routers[i].children; if(children){ for(var j=0; j<children.length; j++){ var grand_children = children[j].children; if(grand_children){ for(var k=0; k<grand_children.length; k++){ if(grand_children[k].path == cur_path){ nav_type = routers[i].type; break; } } } } } } if(nav_type == "home"){ this.defaultActiveIndex = "/"; } else if(nav_type == "enterprise"){ this.defaultActiveIndex = "/enterpriseManager"; } } } watch: { '$route': 'fetchData' } } </script>
附上router配置格式
export default [ { path: '/', type: 'home', //自定义type区分不同模块菜单 name: 'home', redirect: '/dashboard', ponent: Home, menuShow: true, children: [ { path: '/dashboard', ponent: HomeNav, name: 'dashboard', leaf: true, // 只有一个节点 iconCls: 'icon-home', // 图标样式class menuShow: true, children: [ { path: '/dashboard', ponent: Dashboard, name: '首页', menuShow: true } ] }, { path: '/mySet', ponent: HomeNav, name: '我的设置', iconCls: 'el-icon-menu', menuShow: true, children: [ { path: '/mySet/plan', ponent: Plan, name: '行程计划', menuShow: true }, { path: '/mySet/maillist', ponent: Maillist, name: '通讯录', menuShow: true } ] } ] }, { path: '/enterpriseManager', type: 'enterprise', name: 'enterprise', ponent: Home, redirect: '/enterprise/list', menuShow: true, children: [ { path: '/enterpriseList', ponent: EnterpriseNav, name: 'enterpriseList', leaf: true, // 只有一个节点 iconCls: 'icon-home', // 图标样式class menuShow: true, children: [ { path: '/enterprise/list', ponent: EnterpriseList, name: '企业列表', menuShow: true } ] }, { path: '/enterpriseAdd', ponent: EnterpriseNav, name: 'enterpriseAdd', leaf: true, // 只有一个节点 iconCls: 'el-icon-menu', menuShow: true, children: [ { path: '/enterprise/add', ponent: EnterpriseAdd, name: '企业添加', menuShow: true } ] }, { path: '/enterpriseValidate', ponent: EnterpriseNav, name: 'enterpriseValidate', leaf: true, // 只有一个节点 iconCls: 'el-icon-menu', menuShow: true, children: [ { path: '/enterprise/validate', ponent: EnterpriseValidate, name: '企业认证', menuShow: true } ] } ] } ]
补充知识vue手动刷新视图以及其他小问题
最近把手头上一个使用angularJS+jquery各种七七八八组件写的页面拿vue+elementUI重写了一边, 真是极度丝滑, 记录一些vue和elementUI的小问题
1.如果vue中的数据结构比较庞大的话, 十分有可能会出现model更新而视图不更新/model和视图都不更新也不报错的情况, 此时需要手动刷新vue的数据, 在change或click事件中, 使用this.$forceUpdate()手动刷新视图
//像这样 changeSef: function () { //手动刷新视图 var that = this; that.$forceUpdate(); },
2.在vue中使用setTimeout
//错误示范 setTimeout(bidOrderInit, 200); //上面那样是不行的,网上查了下, 大致是说在setTimeout中this指向window对象, //于是乎被定时的方法中就使用不到vue的this对象了 //正确示范 //可以无视对ie的支持时 setTimeout(()=> { this.bidOrderInit(); }, 200); //需要兼容ie时 setTimeout(function () { this.bidOrderInit(); }, 200);
以上这篇Vue页面手动刷新,实现导航栏激活项还原到初始状态就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程