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项目

相关推荐
学Linux的语莫1 天前
Vue 3 入门教程
前端·javascript·vue.js
qq4356947011 天前
Vue04
前端·vue.js
这里是杨杨吖1 天前
SpringBoot+Vue高校在线考试系统 附带详细运行指导视频
vue·在线考试·springboot
万物更新_1 天前
vue框架
前端·javascript·vue.js·笔记
英勇无比的消炎药1 天前
一文吃透TinyRobot Bubble:从基础组件搭建完整AI消息渲染体系
vue.js
英勇无比的消炎药1 天前
深挖底层:TinyRobot Bubble消息气泡组件核心技术原理
vue.js
英勇无比的消炎药1 天前
架构剖析:TinyRobot Bubble渲染器状态管理与工具调用机制
vue.js
英勇无比的消炎药1 天前
多模态消息渲染实战:TinyRobot Bubble内容解析与contentResolver用法
vue.js
gg159357284601 天前
Uni-app跨平台开发全解课程:从零基础到企业级多端落地实战
vue.js·uni-app
阿猫的故乡1 天前
Vue + Axios 从入门到封装:拦截器、错误处理、请求取消、接口管理全搞定
前端·javascript·vue.js