Home > Article > Web Front-end > How to use vue components for data transfer
This time I will show you how to use vue components for data transfer, and what are the precautions for using vue components for data transfer. The following is a practical case, let's take a look.
Vue's component scopes are all isolated and do not allow directreferences to the data of the parent component in the template of the child component. Specific methods must be used to transfer data between components. There are roughly three situations in which data is passed between components:
The parent component passes data to the child component, and the data is passed through props. The child component passes data to the parent component and passes the data through events. Transfer data between two sibling components through event bus.
<template> <p class="child"> {{ msg }} </p> </template> <script> export default { name: 'child', data(){ return { } }, props: ['msg'] </script>In child. In vue, msg is a variable defined in data. Use props: ['msg'] to get the value of msg from the parent component Parent component part:
<template> <p class="child"> child <child :msg="message"></child> </p> </template> <script> import child from './child.vue' export default { name: 'parent', components: { child }, data () { return { message: 'hello vue' } } } </script>When calling the component, Use v-bind to bind the value of msg to the variable message defined in parent.vue, so that the value of message in parent.vue can be passed to child.vue.
Single data flow
When the message of the parent component changes, the child component will automatically update the Method 1: Assign prop to a local variable, and then modify the local variable if you need to modify it, without affecting propexport default { data(){ return { newMessage: null } }, props: ['message'], created(){ this.newMessage = this.message; } }Method 2: Process the prop in the calculation of
export default { props: ['message'], computed: { newMessage(){ return this.message + ' 哈哈哈'; } } }
<template> <p class="child"> <span>用户名:</span> <input v-model="username" @change="sendUser" /> </p> </template>In the html of the subcomponent, when the value in the input changes, the username is passed to parent.vue. First declare a sendUser method and use change
event to call sendUser.
<script> export default { name: 'parend', data () { return { username: '' } }, methods: { sendUser () { this.$emit('changeName', this.username) } } } </script>In sendUser, use $emit to traverse the changeName event and return this.name, where changeName is a custom event, which functions like a relay. This.name will be passed to the parent through this event components. Parent component part:
<template> <p class="parent"> <child @changeName="getUser"></child> <p>用户名:{{user}}</p> </p> </template>Declare a getUser method in the parent component, use the changeName event to call the getUser method, and obtain the parameter username passed from the child component
<script> import child from './child.vue' export default { name: 'parent', components: { child }, data () { return { user: '' } }, methods: { getUser(data) { this.user = data } } } </script>The parameter msg in the getUser method is the parameter uesrname passed from the subcomponent.
<template> <p id="app"> <c1></c1> //组件1 <c2></c2> //组件2 </p> </template>In component c1:
<template> <p class="c1"> page <button @click="changeMsg">click</button> </p> </template> <script> var Bus = new Vue(); //为了方便将Bus(空vue)定义在一个组件中,在实际的运用中一般会新建一Bus.js export default { name: 'c1', data () { return { message: 'hi' } }, methods: { changeMsg () { //点击按钮,将this.message传递给c2 bus.$emit('sendMsg', this.message) } } } </script>In component c2:
<template> <p class="c2"> {{msg}} </p> </template> <script> var Bus = new Vue(); export default { name: 'c2', data () { return { msg: '' } }, created () { bus.$on('sendMsg',(data)=>{ //data即为c1组件中的message this.msg = data }) } } </script>In actual application, the bus is generally extracted:
//Bus.js import Vue from 'vue' const Bus = new Vue() expore default BusComponent call When referenced (import Bus from './Bus.js')However, in this way of introduction, the local scope of the Bus may appear after being packaged by webpack, that is, two different Buses are referenced. Resulting in normal communication
Practical application:
import Vue from 'vue' const Bus = new Vue() var app= new Vue({ el:'#app', data:{ Bus } })Pass
this.$root.Bus.$on() in the subcomponent , this.$root.Bus.$emit() to call
How to use WebPack to configure vue multi-page
How to use the Node.js sandbox environment
The above is the detailed content of How to use vue components for data transfer. For more information, please follow other related articles on the PHP Chinese website!