vue 中几种传值方法(3种)
前言
vue项目中,组件跟组件之间数据的传递是很普遍的行为,在这里几种常见的vue组件跟组件之间传值方式,其中,主要有父子组件,非父子组件传值。
父组件向子组件传值
方法父组件内设置要传的数据,在父组件中引用的子组件上绑定一个自定义属性并把数据绑定在自定义属性上,在子组件添加参数props接收即可。具体可参考。
父组件传递参数代码如下
<template> <center-template :form='userinfo'></center-template> </template> <script> import CenterTemplate from '../../ponents/admin/userCenterTemplate' export default { ponents: { 'center-template': CenterTemplate }, data () { return { userinfo: {name: 'jack'} } }, } </script>
上面代码,通过在子组件上面绑定动态参数:form='userinfo'将父组件中的参数传递给子组件,子组件就可以通过props来进行接收。
子组件接收参数代码如下
... export default { props: { // 接收 form: { userinfo: Object } } }, } // 另一种写法 export default { props: { // 接收 form: ['userinfo'] } }, }
上面代码中,还可以使用数组来接受参数,不能指定参数的类型。
子组件向父组件传值
方法子组件通过vue实例方法$emit进行触发并且可以携带参数,父组件监听使用@(v-on)进行监听,然后进行方法处理。
子组件向上传值
<template> <ul class="letter_city"> <li @click="selectItem('子组件向父组件传值')"> </li> </ul> </template> <script> export default { methods: { selectItem(value) { this.$emit('selectItems', value) } } } </script>
上面代码中,this指代的是vue实例,子组件通过$emit向父组件触发事件和传递参数。
父组件监听子组件传来的值
<template> <city-pages @selectItem='selectItem'></city-pages> </template> <script> import cityPages from './cityPages' export default { ponents: { cityPages }, methods: { selectItem(value) { console.log(value) // 子组件向父组件传值 } } } </script>
上面代码中,在子组件中监听方法,如果子组件触发方法,父子间这边就可以得到子组件传过来的参数了。
非父子组件传值一
Event BUS总线方法通过新建一个vue实例,来实现$on接收和$emit 来触发事件
1、新建bus.js文件
// mon/bus.js import Vue from 'vue'; // 使用 Event Bus const bus = new Vue(); export default bus;
2、组件1(接收通知信息)
import bus from '@/mon/bus.js' export default{ data(){ return { collapseData: '' } }, created() { // 监听collapse,有变动就会收到通知,并改变collapseData值 bus.$on('collapse', msg => { this.collapseData = msg }) } }
3、组件2(发布信息)
import bus from '@/mon/bus.js' export default { methods: { sendData(){ // 发布信号,触发这个函数,其他的接收函数都会收到相应的信息 bus.$emit('collapse', '信息') } } }
非父子组件传值二
借组vux插件实现组件之间的传值。
1、通过npm加载vuex,创建store.js文件,然后在main.js中引入,store.js文件代码如下
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex); const state = { message:'Hello World' }; const mutations = { newMessage(state,msg){ state.message = msg } } export default new Vuex.Store({ state, mutations })
3、在组件中存vuex的值,一般如下
state里面的值只能通过Action来提交来修改和赋值。
<template> <div> <input type="text" @blur=saveName(username) v-model="username"> </div> </template> <script type="text/javascript"> // 引入mapActions,很重要 import { mapActions } from 'vuex' export default { data() { return { username:'', password: '' } }, methods: { ...mapActions({ // 在input 的blur 事件中触发回调,并将输入值作为参数返回到store中 saveName: 'saveName' }) } } </script>
3、在组件中获取Vuex的值,一般如下
<template> <div id="list"> {{_name}} </div> </template> <script> import {mapState} from 'vuex' export default { name: 'List', data() { return{} }, puted: { // 1普通写法 // name() { return this.$store.state.name } // 2简洁写法 //...mapState(['name']) // 3重命名 ...mapState({_name: "name"}) } </script>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程