Home Web Front-end Vue.js Component data transfer and event transfer implementation methods in Vue documentation

Component data transfer and event transfer implementation methods in Vue documentation

Jun 20, 2023 am 10:21 AM
data transfer vue component delivery event delivery

Vue is a popular front-end framework that has componentization features that allow developers to decompose a complex page into small and independent modules. In Vue, data transfer and event transfer between components are very important topics. In this article, we will introduce in detail the implementation methods of component data transfer and event transfer in Vue.

1. Component data transfer

In Vue, the transfer of component data is divided into two categories, one is the transfer of parent component to child component, and the other is the transfer of child component to parent component. of transmission.

1. Parent component passes data to child component

Parent component needs to use props option to pass data to child component. Props is a way for child component to receive data passed by parent component. Pass data to the child component through v-bind: attribute name in the parent component, and receive data through the props option in the child component.

Look at the code in the parent component first:

<template>
  <div>
    <child-component :title="title"></child-component>
  </div>
</template>

<script>
import ChildComponent from './child.vue'

export default {
  components: { ChildComponent },
  data () {
    return {
      title: 'this is the title'
    }
  }
}
</script>
Copy after login

In the above code, we define a main component and pass the title attribute to the child-component through v-bind: components.

Then look at the code of the subcomponent:

<template>
  <div>
    <h1>{{ title }}</h1>
  </div>
</template>

<script>
export default {
  props: {
    title: {
      type: String,
      required: true
    }
  }
}
</script>
Copy after login

In the above code, we define a subcomponent and receive the title attribute passed by the parent component through the props option.

2. Subcomponent passes data to parent component

To pass data from subcomponent to parent component, you need to use the $emit method. $emit is a way for subcomponent to pass data to parent component. Use the $emit method in the child component to trigger a custom event and pass the data that needs to be passed. Listen to this custom event in the parent component through the @event name, and receive the data passed by the child component in the event response function. .

Look at the code in the subcomponent first:

<template>
  <div>
    <button @click="increment">{{ count }}</button>
  </div>
</template>

<script>
export default {
  data () {
    return {
      count: 0
    }
  },
  methods: {
    increment () {
      this.count++
      this.$emit('increment', this.count)
    }
  }
}
</script>
Copy after login

In the above code, we define a subcomponent and use the $emit method to trigger a custom event increment when the button is clicked. And pass the current count value as a parameter to the parent component.

Then look at the code of the parent component:

<template>
  <div>
    <h1>{{ totalCount }}</h1>
    <child-component @increment="onChildIncrement"></child-component>
  </div>
</template>

<script>
import ChildComponent from './child.vue'

export default {
  components: { ChildComponent },
  data () {
    return {
      totalCount: 0
    }
  },
  methods: {
    onChildIncrement (count) {
      this.totalCount += count
    }
  }
}
</script>
Copy after login

In the above code, we define a parent component, and when listening to the increment event of the child component, pass the count value as a parameter to In the response function onChildIncrement, and update the value of totalCount in the response function.

2. Component event delivery

In Vue, event delivery between components can be achieved through the event bus and vuex.

1. Event bus

The event bus is a simple event delivery method. It creates a central event bus. All components can register events or trigger events to the event bus. In Vue, you can use the Vue.prototype.$bus property to create an event bus.

Let’s first look at how to use the event bus:

// main.js中创建事件总线
import Vue from 'vue'

Vue.prototype.$bus = new Vue()

// 在需要传递事件的组件中注册事件和触发事件
this.$bus.$emit('my-event', data)

this.$bus.$on('my-event', (data) => { ... })
Copy after login

In the above code, we created an event bus through the Vue.prototype.$bus property in the main.js file, and then in In the component that needs to pass the event, trigger the custom event my-event through the $emit method, and pass the data that needs to be passed as a parameter to the response function of the event; in the component that needs to receive the event, listen to the custom event my- through the $on method. event, and receive the passed data in the event response function.

2.vuex

vuex is an officially recommended state management solution. It places the state of all components in a global state tree. All components can access the global state from Get and update status in the tree. In vuex, you can use store objects to store global state, and modify global state through mutations, actions, and getters.

Let’s first look at how to use vuex:

// store.js文件
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment (state) {
      state.count++
    }
  },
  actions: {
    asyncIncrement (context) {
      setTimeout(() => {
        context.commit('increment')
      }, 1000)
    }
  },
  getters: {
    doubleCount (state) {
      return state.count * 2
    }
  }
})

// 在组件中使用vuex
import { mapState, mapMutations, mapActions, mapGetters } from 'vuex'

export default {
  computed: {
    ...mapState({
      count: state => state.count
    }),
    ...mapGetters([
      'doubleCount'
    ])
  },
  methods: {
    ...mapMutations([
      'increment'
    ]),
    ...mapActions([
      'asyncIncrement'
    ])
  }
}
Copy after login

In the above code, we define a store object that stores global state in the store.js file, and use mutations, actions, and getters to modify and obtain the global state; in the component, map the state, modification function and action function in the store through auxiliary functions such as mapState, mapMutations, mapActions and mapGetters, and use them in the component.

Conclusion

In Vue, data transfer and event transfer between components are very important topics. For different scenarios and needs, we can use props, $emit, event bus and vuex and other methods to achieve data transfer and event transfer. Mastering these skills allows us to organize and manage our Vue applications more flexibly.

The above is the detailed content of Component data transfer and event transfer implementation methods in Vue documentation. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Use provide and inject in Vue to implement data transfer and performance optimization between components Use provide and inject in Vue to implement data transfer and performance optimization between components Jul 17, 2023 pm 07:19 PM

Use provide and inject in Vue to achieve data transfer and performance optimization between components. In Vue, data transfer between components is a very common requirement. Sometimes we want to provide data at a node in the component tree and then use the data in its descendant components. In this case, we can use Vue's provide and inject to achieve this. In addition to data transfer, provide and inject can also be used for performance optimization, reducing the level of props transfer and improving component performance. prov

How to use PHP language to call API interface to realize data transfer and synchronization between systems? How to use PHP language to call API interface to realize data transfer and synchronization between systems? Sep 05, 2023 am 11:26 AM

How to use PHP language to call API interface to realize data transfer and synchronization between systems? When developing and designing modern systems, we often need to transfer and synchronize data between different systems. A common method is to use API interfaces to implement communication between systems. This article will introduce how to use PHP language to call API interface to achieve data transfer and synchronization between systems. API (Application Programming Interface) is a programmatic way to implement different systems

How to implement communication and data transfer between parent and child components in Vue components How to implement communication and data transfer between parent and child components in Vue components Oct 08, 2023 pm 09:51 PM

Vue is a popular front-end development framework that provides many convenient functions and mechanisms to help us build reusable and efficient componentized applications. In Vue, parent-child component communication and data transfer are one of the common requirements. This article will introduce in detail how to implement communication and data transfer between parent and child components in Vue, and provide specific code examples. In Vue, communication between parent and child components can be achieved through props and $emit methods. Props is the mechanism for parent components to pass data to child components, and $emi

Vue component communication: use v-bind directive for data transfer Vue component communication: use v-bind directive for data transfer Jul 07, 2023 pm 04:46 PM

Vue component communication: Use the v-bind instruction for data transfer. Vue.js is a popular front-end framework that provides powerful component development capabilities. In Vue applications, component communication is an important issue. The v-bind instruction is a data transfer method provided by the Vue framework. This article will introduce how to use the v-bind instruction to transfer data between components. In Vue, component communication can be divided into two situations: parent-child component communication and sibling component communication. Below we will introduce from these two aspects respectively:

How to use v-bind directive to pass data in Vue How to use v-bind directive to pass data in Vue Jun 11, 2023 am 10:45 AM

Vue is a popular JavaScript framework that uses many directives to make front-end development easier and more flexible. Among them, the v-bind instruction is a very important instruction in Vue, which allows us to dynamically bind data to html elements. The syntax of the v-bind directive is very simple and can be used on any html tag, for example: &lt;imgv-bind:src="imageSrc"&gt; In this example, v-bind refers to

Deep understanding of browser event delivery: revealing the event bubbling mechanism Deep understanding of browser event delivery: revealing the event bubbling mechanism Feb 19, 2024 pm 07:43 PM

Event delivery mechanism in the browser: Exploring the mystery of event bubbling Events are an important concept in front-end development, and the event delivery mechanism in the browser is even more critical. In our daily front-end development, event binding and processing are often involved. Understanding the event delivery mechanism, especially the principle of event bubbling, can help us better understand and handle events. When doing front-end development in the browser, our pages are usually composed of elements. On these elements we can add various events to respond to user operations. And when

How to use routing in Vue to implement data transfer and state management between pages? How to use routing in Vue to implement data transfer and state management between pages? Jul 21, 2023 am 08:18 AM

How to use routing in Vue to implement data transfer and state management between pages? In Vue, Router is one of the core plug-ins for switching between pages. In addition to page jumps, routing can also be used to implement data transfer and status management. This article will introduce how to use Vue's routing plug-in (VueRouter) to realize data transfer and status management between pages, and provide corresponding code examples. Basic use of routing VueRouter is the official routing plug-in of Vue.js. It can

Front-end and back-end data transfer problems encountered in Vue development Front-end and back-end data transfer problems encountered in Vue development Oct 08, 2023 pm 01:25 PM

Front-end and back-end data transfer problems encountered in Vue development require specific code examples. With the development of front-end technology, Vue is a popular front-end framework. More and more developers choose to use Vue to develop web applications. In the Vue development process, the transmission of front-end and back-end data is a very important link. This article will introduce some common front-end and back-end data transfer problems in Vue development, and provide specific code examples to solve these problems. The front-end and back-end data transfer formats are not unified. During the front-end and back-end data transfer process,

See all articles