search
HomeWeb Front-endFront-end Q&AHow to make calls between vue components

Vue is a very popular JavaScript framework in modern web development, of which components are a very important part. In Vue, components can be reused, and communication between components is also a problem often encountered in development. This article will introduce the communication issues between Vue components and explore in detail how to "make calls" between Vue components.

1. Communication between Vue components

In Vue, communication between components is mainly divided into two ways: parent-child component communication and non-parent-child component communication.

1. Parent-child component communication

In the Vue component, the parent component can pass data to the child component through props.

Parent component Template:

<template>
  <div>
    <child :message="message"></child>
  </div>
</template>

Child component Script:

<script>
  export default {
    props: ['message']
  }
</script>

The way the parent component transfers data to the child component is very simple. You only need to add the props attribute to the child component tag. , and just add the transfer data required by the subcomponent.

After receiving the data passed by the parent component, the child component can use this data in the template:

<template>
  <div>
    {{message}}
  </div>
</template>

Transmitting data to the child component through props is one of the most commonly used parent-child communication methods in Vue. one. In practice, we may also need to execute the parent component's methods or manipulate the parent component's data. In this case, the event emit can be used to communicate between the parent component and the child component.

Parent component:

<template>
  <div>
    <child @sendMsg="updateMessage"></child>
  </div>
</template>

<script>
  export default {
    data () {
      return {
        message: ''
      }
    },
    methods: {
      updateMessage (msg) {
        this.message = msg
      }
    }
  }
</script>

Use $emit method to trigger sendMsg event in child component

<script>
  export default {
    methods: {
      sendMessage () {
        this.$emit('sendMsg', 'Hello Vue!')
      }
    }
  }
</script>

2. Non-parent-child component communication

In Vue, if If the component is not a parent-child relationship, the communication between components can use the event bus officially provided by Vue.

Specific implementation method:

Create a new eventBus.js file

import Vue from 'vue'

export const eventBus = new Vue()

In the component that needs to communicate, import eventBus.js and use $emit to trigger the event:

<script>
  import { eventBus } from './eventBus.js'

  export default {
    methods: {
      sendMessage () {
        eventBus.$emit('sendMsg', 'Hello Vue!')
      }
    }
  }
</script>

Receive events:

<template>
  <div>
    <h1 id="message">{{ message }}</h1>
  </div>
</template>

<script>
  import { eventBus } from './eventBus.js'

  export default {
    data () {
      return {
        message: ''
      }
    },
    created () {
      eventBus.$on('sendMsg', (msg) => {
        this.message = msg
      })
    }
  }
</script>

This method allows communication between different components, but there are certain disadvantages: when the application is very complex, it is difficult to track the communication links between components.

2. Communication methods and selections between components

In the application development process, it is necessary to choose a communication method suitable for the application to improve development efficiency and performance.

1. Parent-child component communication

is suitable for situations where parent-child components need to transfer data or perform operations. This method is relatively simple and easy to maintain and debug.

2. Non-parent-child component communication

Applicable to situations where communication is required between cross-level, brothers and other non-parent-child components. Using the event bus method can simply implement communication between components, but it can easily lead to difficulty in debugging and increased complexity.

3.Vuex

Vuex is the state management library officially provided by Vue, which is used to manage the state in the application (including data and operations). Suitable for larger projects when large amounts of data need to be shared.

Using Vuex, you can put the communication between components into the Vuex store, and then let the required components obtain the data in the store through getters or use actions to trigger state changes in the store, update the data in the store, and then Notify other components.

Summary:

In Vue development, the communication problem between components is a common problem. We can choose parent-child component communication, non-parent-child component communication, and Vuex status according to the actual situation. manage. Proper use of these methods can improve application development efficiency and performance.

The above is the detailed content of How to make calls between vue components. For more information, please follow other related articles on the PHP Chinese website!

Statement
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
CSS: Can I use multiple IDs in the same DOM?CSS: Can I use multiple IDs in the same DOM?May 14, 2025 am 12:20 AM

No,youshouldn'tusemultipleIDsinthesameDOM.1)IDsmustbeuniqueperHTMLspecification,andusingduplicatescancauseinconsistentbrowserbehavior.2)Useclassesforstylingmultipleelements,attributeselectorsfortargetingbyattributes,anddescendantselectorsforstructure

The Aims of HTML5: Creating a More Powerful and Accessible WebThe Aims of HTML5: Creating a More Powerful and Accessible WebMay 14, 2025 am 12:18 AM

HTML5aimstoenhancewebcapabilities,makingitmoredynamic,interactive,andaccessible.1)Itsupportsmultimediaelementslikeand,eliminatingtheneedforplugins.2)Semanticelementsimproveaccessibilityandcodereadability.3)Featureslikeenablepowerful,responsivewebappl

Significant Goals of HTML5: Enhancing Web Development and User ExperienceSignificant Goals of HTML5: Enhancing Web Development and User ExperienceMay 14, 2025 am 12:18 AM

HTML5aimstoenhancewebdevelopmentanduserexperiencethroughsemanticstructure,multimediaintegration,andperformanceimprovements.1)Semanticelementslike,,,andimprovereadabilityandaccessibility.2)andtagsallowseamlessmultimediaembeddingwithoutplugins.3)Featur

HTML5: Is it secure?HTML5: Is it secure?May 14, 2025 am 12:15 AM

HTML5isnotinherentlyinsecure,butitsfeaturescanleadtosecurityrisksifmisusedorimproperlyimplemented.1)Usethesandboxattributeiniframestocontrolembeddedcontentandpreventvulnerabilitieslikeclickjacking.2)AvoidstoringsensitivedatainWebStorageduetoitsaccess

HTML5 goals in comparison with older HTML versionsHTML5 goals in comparison with older HTML versionsMay 14, 2025 am 12:14 AM

HTML5aimedtoenhancewebdevelopmentbyintroducingsemanticelements,nativemultimediasupport,improvedformelements,andofflinecapabilities,contrastingwiththelimitationsofHTML4andXHTML.1)Itintroducedsemantictagslike,,,improvingstructureandSEO.2)Nativeaudioand

CSS: Is it bad to use ID selector?CSS: Is it bad to use ID selector?May 13, 2025 am 12:14 AM

Using ID selectors is not inherently bad in CSS, but should be used with caution. 1) ID selector is suitable for unique elements or JavaScript hooks. 2) For general styles, class selectors should be used as they are more flexible and maintainable. By balancing the use of ID and class, a more robust and efficient CSS architecture can be implemented.

HTML5: Goals in 2024HTML5: Goals in 2024May 13, 2025 am 12:13 AM

HTML5'sgoalsin2024focusonrefinementandoptimization,notnewfeatures.1)Enhanceperformanceandefficiencythroughoptimizedrendering.2)Improveaccessibilitywithrefinedattributesandelements.3)Addresssecurityconcerns,particularlyXSS,withwiderCSPadoption.4)Ensur

What are the main areas where HTML5 tried to improve?What are the main areas where HTML5 tried to improve?May 13, 2025 am 12:12 AM

HTML5aimedtoimprovewebdevelopmentinfourkeyareas:1)Multimediasupport,2)Semanticstructure,3)Formcapabilities,and4)Offlineandstorageoptions.1)HTML5introducedandelements,simplifyingmediaembeddingandenhancinguserexperience.2)Newsemanticelementslikeandimpr

See all articles

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

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

SecLists

SecLists

SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor