vue App.vue里的公共组件改变值触发其他组件或.vue页面监听

栏目: JavaScript · 发布时间: 5年前

内容简介:解决方案我是用vuex数据仓库来存储词条的,当词条改变时,修改数据仓库里的词条然后在.vue页面里监听这个词条,当词条改变时触发请求数据的事件
业务场景重现

现在我的App.vue里面有一个头部的公共组件,头部组件里有一个输入框,当我输入词条时,将词条传进App.vue里的<router-view>里的.vue页面,并进行查询获取数据

解决思路如下:

1.如何拿到头部的词条

2.当词条改变时如何触发.vue里的请求数据事件

解决方案

我是用vuex数据仓库来存储词条的,当词条改变时,修改数据仓库里的词条

然后在.vue页面里监听这个词条,当词条改变时触发请求数据的事件

代码

数据仓库store.js

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
    searchKey: ''       //存库词条的变量
  },
  mutations: {                 //修改数据仓库的事件
    changeSearchKey(state,value){
      state.searchKey = value
    }
  },
  actions: {                 //推荐使用的异步修改数据仓库
    setSearchKey(context,value){   
      context.commit('changeSearchKey',value)
   }
  }
})

App.vue里的header组件

goSearch: function(){
            if(this.value){
                this.$store.dispatch('setSearchKey',this.value)  //当输入词条时,将词条更新到数据仓库
            }
        },

vue页面里监听词条

computed: {                     监听词条
        getSearchKey(){
            return this.$store.state.searchKey
        }
    },
    watch: {
        getSearchKey: {
            handler(newValue,oldValue){  //当词条改变时执行事件
                this.recordis(newValue)
                // console.log('new',newValue)
                // console.log('old',oldValue)
            }
        }

    },

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

白话区块链

白话区块链

蒋勇 / 文延、嘉文 / 机械工业出版社 / 2017-10-1 / 59.00

由浅入深:从比特币开始,到区块链技术的骨骼(密码算法)和灵魂(共识算法),再到目前知名的区块链框架介绍,到最后从零构建一个微型区块链系统(微链),循序渐进。 多图多表:各种示例以及图表,通过流程图与示意图介绍比特币的源码编译、以太坊智能合约的开发部署、超级账本Fabric的配置使用、模拟比特币的微型区块链系统的设计实现等,形象而直观。 白话通俗:通过“村民账本记账”、“百花村选举记账”......一起来看看 《白话区块链》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

URL 编码/解码
URL 编码/解码

URL 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具