Vue兄弟组件(非父子组件)状态共享与传值
前言:网上大部分文章写的有点乱,很少有讲得易懂的文章。
所以,我写了篇在我能看得懂的基础上又照顾到大家的文章 =。=
- 作者:X1aoYE
- 备注:此文原创,转载请注明~ 内容里的<br>请无视。。
关键字:Vue、非父子组件、兄弟组件、传值、共享状态
- 应用例子:
- 主题颜色更换
- 购物车传值
- 就像名字所说的兄弟组件传值,自己理解其他例子了哈~
- 小型项目:
推荐使用 global event bus (事件总线) ,不然小项目里用 Vuex 相对来说会挺繁琐
步骤:
1. 新建一个 bus.vue (只是个 .vue ,不用想太多)
import Vue from 'vue' //import一个vue类
export const bus = new Vue() //实例化并将它export
2. 使用
在我们的一个组件(这里指的是发送方)里:
import { bus } from 'bus.js'
// 其他代码~
bus.$emit('myEvent', 'this.mydata')
// 其他代码~
// 解释:bus.$emit('自定义事件名',要传送的数据);
3. 接着使用 bus.vue
紧接着在我们另一个组件(这里指的是接收方)里:
备注:bus.$on('事件名',callback) ---------- callback即指回调$emit要传送的数据;
import { bus } from 'bus.js'
created () { //监听传值
bus.$on('myEvent', (mydata) => {
this.mydata = mydata;
})
}
备注:若只想监听一次事件 ,则使用bus.$once
注销:bus.$off('myEvent', ~~~自己写~~~);
步骤大致就这样~
- 中大型项目:
推荐使用 Vuex ,
解释一波:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式;
vuex解决了组件之间同一状态的共享问题 (解决了不同组件之间的数据共享) ,使组件里面的数据持久化。
1. 安装vuex :cnpm install vuex --save (什么是cnpm就不解释了,能学到Vuex的应该都了解cnpm了)
2. 创建一个 vuex 文件夹,并在里面新建一个 store.js 写入以下代码:
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
接着往下写:
state 定义数据:state在vuex中用于存储数据
//1.state在vuex中用于存储数据
var state={ //存放数据,数据中心
count:1,
// 其他数据格式:orderList: [],
// 其他数据格式:params: {}
}
getters 类似计算属性:
//2.
var getters= {
computedCount: (state) => {
return state.count*2
}
}
mutations 定义方法:mutations里面放的是方法,方法主要用于改变state里面的数据
//3.mutations里面放的是方法,方法主要用于改变state里面的数据
var mutations={
incCount(){
++state.count;
}
}
action 定义方法:异步操作,Action 提交的是 mutation,而不是直接变更状态。
//4.
var actions= {
incMutationsCount(context) { /*因此你可以调用 context.commit 提交一个 mutation*/
context.commit('incCount'); /*执行 mutations 里面的incCount方法 改变state里面的数据*/
//此处按照实际情况扩展~
}
}
暴露!:暴露上面那四个~
const store = new Vuex.Store({
state,
mutations,
getters,
actions
})
export default store;
3. 组件里去使用 Vuex:
(1). 获取state里面的数据
this.$store.state.数据
(2). 获取 getters里面方法返回的的数据 (一般vue 和 store 进行交互 用 $store.getters, getters的值放在计算属性里,动态绑定在计算属性computed里)
this.$store.getters.computedCount
(3). 触发 mutations 改变 state里面的数据 (别记混了)
this.$store.commit('incCount');
(4). 触发 actions里面的方法 (别记混了)
this.$store.dispatch('incMutationsCount'); ps:这个 incMutationsCount 会再去 执行 mutations 里面的incCount方法
4. 在src下新建一个文件夹store,接着新建一个文件index.js来放store对象。记得在 main.js 里添加store
main.js:
importstore from'./store/index'
new Vue({
el: '#app',
router,
store,
template: '<按你的写/>',
//第一层
components: { 按你的写 }
})
index.js:
import Vuex from 'vuex'
import Vue from 'vue'
import storefrom './modules/store' //这个是我的store.js
Vue.use(Vuex) export default new Vuex.Store({
modules:{ //模型
store
}
})
大概就这样~
这只是基础步骤,详细的要自己按照自己的详细情况加~
Vue兄弟组件(非父子组件)状态共享与传值的更多相关文章
- 【vue】父组件主动调用子组件 /// 非父子组件传值
一 父组件主动调用子组件: 注意:在父组件使用子组件的标签上注入ref属性,例如: <div id="home"> <v-header ref="he ...
- Vue 组件 非父子组件通信
有时候两个组件也需要通信(非父子关系),在简单的场景下,可以使用一个空的vue实例作为中央事件总线: var bus = new Vue(); //触发组件a中的事件 bus.$emit('id-se ...
- Vue bus的使用(兄弟|非父子组件传值)-->可以使用一个空的Vue实例作为中央事件总线new Vue()
1.在main.js中注册全局的bus Vue.prototype.bus=new Vue(); 2.在组建中使用 子组建使用:this.bus.$emit('自定义事件名',data) metho ...
- vue 2 使用Bus.js进行兄弟(非父子)组件通信 简单案例
vue2中废弃了$dispatch和$broadcast广播和分发事件的方法.父子组件中可以用props和$emit().如何实现非父子组件间的通信,可以通过实例一个vue实例Bus作为媒介,要相互通 ...
- 简述在Vue脚手架中,组件以及父子组件(非父子组件)之间的传值
1.组件的定义 组成: template:包裹HTML模板片段(反映了数据与最终呈现给用户视图之间的映射关系) 只支持单个template标签: 支持lang配置多种模板语法: script:配置Vu ...
- Vue 非父子组件通信方案
Vue 非父子组件通信方案 概述 在 Vue 中模块间的通信很普遍 如果是单纯的父子组件间传递信息,父组件可以使用 props 将数据向下传递到子组件,而在子组件中可以使用 events (父组件需要 ...
- Vue 非父子组件通信
组件是Vue核心的一块内容,组件之间的通信也是很基本的开发需求.组件通信又包括父组件向子组件传数据,子组件向父组件传数据,非父子组件间的通信.前两种通信Vue的文档都说的很清楚,但是第三种文档上确只有 ...
- vue父子组件及非父子组件通信
1.父组件传递数据给子组件 父组件数据如何传递给子组件呢?可以通过props属性来实现 父组件: <parent> <child :child-msg="msg" ...
- Vue父子组件及非父子组件如何通信
1.父组件传递数据给子组件 父组件数据如何传递给子组件呢?可以通过props属性来实现 父组件: 子组件通过props来接收数据: 方式1: 方式2 : 方式3: 这样呢,就实现了父组件向子组件传递数 ...
随机推荐
- WPF Binding的代码实现
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threa ...
- Java CLASSPATH 引发的问题
# 问题 在做 OJ 的时候,由于程序需要编译运行,出于安全性考虑,我选择利用类 ProcessBuilder ,一个通过命令行调用 Java 程序的类. 我在 Eclipse 中或者在 CMD 中执 ...
- Ogre 1.7.0,VS2005编译全过程傻瓜式教程
最近下了最新版Ogre 1.7.0,从下载到最后编译运行成功Ogre自带的Sample花了将近一下午时间. 网上有很多编译Ogre的教程,这里整理我看过的教程,加上自己的经验再详细总结一遍. 第一步: ...
- ASP.NET MVC 学习笔记1 Talk about controller & route
For the sake of learning programming better, I'd like to increase the frequency of using English. So ...
- vs2015 生成 cordova 页面中文乱码
原文:vs2015 生成 cordova 页面中文乱码 1.用VS2015新创建Cordova项目,启动运行index.html 中文显示乱码 解决方案: 1.使用text/html通用解析编码utf ...
- workerman源码分析之启动过程
PHP一直以来以草根示人,它简单,易学,被大量应用于web开发,非常可惜的是大部分开发都在简单的增删改查,或者加上pdo,redis等客户端甚至分布式,以及规避语言本身的缺陷.然而这实在太委屈PHP了 ...
- shell条件测试结构
条件测试结构 if/then结构用来判断命令列表的退出状态码是否为0(因为在UNIX惯例, 0表示"成功"), 如果成功的话, 那么就执行接下来的一个或多个命令. 有一个专有命令[ ...
- 改善C#程序的建议6:在线程同步中使用信号量
原文:改善C#程序的建议6:在线程同步中使用信号量 所谓线程同步,就是多个线程之间在某个对象上执行等待(也可理解为锁定该对象),直到该对象被解除锁定.C#中对象的类型分为引用类型和值类型.CLR在这两 ...
- .NET框架中系列专业技术术语和缩写
CIL (Common Intermediate Language) 公共中间语言 : CIL最初是随着.NET由微软一起发布的,之前也叫MSIL(Microsoft Intermediate Lan ...
- Delphi Thread.Queue与Synchronize的区别(差别: Synchronize是阻塞,Queue是非阻塞)
前话: 其实大家要学会看源码, 我接下来要说的这些东东,与其等别人讲,还不如自己搞几个代码试一下,印象还深刻点 TThread.Queue和TThread.Synchronize的区别, 效果上:二 ...