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

相关推荐
前端摸鱼匠1 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker1 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
Python私教11 小时前
Pure-Admin-Thin 深度解析:完整版和精简版到底怎么选?
vue.js·人工智能·开源
ayqy贾杰14 小时前
Cursor SDK发布!开发者可直接搬走其内核
前端·vue.js·面试
李白的天不白14 小时前
vue 数据格式问题
前端·vue.js·windows
小白蒋博客14 小时前
【ai开发段永平投资理财的知识图谱网站】第一天:搭 Vite + Vue 项目,跑通 Hello World
vue.js·人工智能·trae
@yanyu6661 天前
登录注册功能-明文
vue.js·springboot
滕青山1 天前
在线PDF拆分工具核心JS实现
前端·javascript·vue.js
jay神1 天前
基于团队模式的C程序设计课程辅助教学管理系统
java·spring boot·vue·web开发·管理系统
钛态1 天前
前端TypeScript高级技巧:让你的代码更安全
前端·vue·react·web