Vue实现全局设置一个刷新按钮 只刷新当面路由页面 不跳转操作功能

javascript 复制代码
项目中实现实现全局设置一个刷新按钮 只刷新当面路由页面 不跳转操作功能
PSPPSPS 
比如我在layout里面的全局设置一个刷新功能按钮
进入到了a b c的路由页面 基于筛选条件搜索后返回的数据
点击全局刷新的按钮对应的每个路由页面返回初始化的状态数据
并不跳转默认页面 实现刷新操作功能

这里需要使用到兄弟组件功能 具体如下

Nuxt项目

  1. 创建一个全局事件总线(EventBus)
javascript 复制代码
在 plugins/ 目录下新建文件:event-bus.ts
javascript 复制代码
// plugins/event-bus.js
import Vue from 'vue'

export const EventBus = new Vue()
javascript 复制代码
然后在 nuxt.config.js 中注册它:
javascript 复制代码
// nuxt.config.js
export default {
  plugins: [
    '~/plugins/event-bus'
  ]
}
  1. 在 layout 组件中 emit 事件
javascript 复制代码
layout就是你的全局页面 相当于header  container footer 的总布局里面
具体写在哪里看你的项目的全局页在哪
javascript 复制代码
假设你的全局刷新在这里
 <el-button type="primary" @click="btnReset">刷新</el-button>
 <script>
 import { EventBus } from '~/plugins/event-bus'//引入使用

btnReset() {
  EventBus.$emit('global-refresh')
}
 </script>

3.在你的a b c 等的路由页面修改

javascript 复制代码
import { EventBus } from '~/plugins/event-bus'

created() {
  this.loadData()
  EventBus.$on('global-refresh', this.handleGlobalRefresh)
},
beforeDestroy() {
  EventBus.$off('global-refresh', this.handleGlobalRefresh)
},
methods: {
resetFilters() {
  this.queryParam.regionIds = [];// 默认的条件保持空
  this.selectedNodes = [];// 默认的条件保持空
}
  handleGlobalRefresh() {
  this.resetFilters();//这个是你的筛选条件 写这个点击刷新回到初始化状态数据
  this.loadData();
  }
}

VUE项目

相关推荐
小光学长2 小时前
基于Vue的儿童手工创意店管理系统as8celp7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
meichaoWen2 小时前
【Vue】Vue框架的基础知识强化
前端·javascript·vue.js
小光学长2 小时前
基于Vue的地铁综合服务管理系统7949eg04(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
天天向上10243 小时前
vue3 抽取el-dialog子组件
前端·javascript·vue.js
Zzzzzxl_3 小时前
互联网大厂前端面试实录:HTML5、ES6、Vue/React、工程化与性能优化全覆盖
性能优化·vue·es6·react·html5·前端面试·前端工程化
自然 醒4 小时前
企业微信自建应用开发详细教程,如何获取授权链接?如何使用js-sdk?
javascript·vue.js·企业微信
AKclown5 小时前
基于Monaco的diffEditor实现内容对比
前端·vue.js·react.js
gongzemin5 小时前
使用阿里云ECS部署前端应用
前端·vue.js·后端
用户9714171814275 小时前
前端开发中的跨域问题:Vite 开发环境配置指南
vue.js·vite