Detailed explanation of the use of $emit in Vue.js

Detailed explanation of the use of $emit in Vue.js

1. Parent components can use props to pass data to child components.

2. Child components can use $emit to trigger custom events of parent components.

vm.$emit( ​​event, arg ) //Trigger the event on the current instance

vm.$on( event, fn ); //Run fn after listening to event;

For example: subcomponent:

<template>
  <div class="train-city">
    <h3>ToCity passed from parent component to child component:{{sendData}}</h3> 
    <br/><button @click='select(`Dalian`)'>Click here to emit 'Dalian' to the parent component</button>
  </div>
</template>
<script>
  export default {
    name:'trainCity',
    props:['sendData'], // Used to receive data passed from the parent component to the child component methods:{
      select(val) {
        let data = {
          cityname: val
        };
        this.$emit('showCityName',data);//After the select event is triggered, the showCityName event is automatically triggered}
    }
  }
</script>

Parent component:

<template>
    <div>
        <div>Parent component's toCity{{toCity}}</div>
        <train-city @showCityName="updateCity" :sendData="toCity"></train-city>
    </div>
<template>
<script>
  import TrainCity from "./train-city";
  export default {
    name:'index',
    components: {TrainCity},
    data () {
      return {
        toCity:"Beijing"
      }
    },
    methods:{
      updateCity(data){//Trigger the child component city selection-select city event this.toCity = data.cityname;//Change the value of the parent component console.log('toCity:'+this.toCity)
      }
    }
  }
</script>

Figure 1: Click on the previous data

Figure 2: Data after clicking

This is the end of this article about the detailed case study of $emit usage in Vue.js. For more relevant content on the usage of $emit in Vue.js, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Vue.js+boostrap project practice (case detailed explanation)
  • Vue.js implements tab switching and color change operation explanation
  • Detailed explanation of the usage of scoped slots in Vue.js slots
  • Vue.js implements calendar function
  • Vue.js implements timeline function
  • Vue.js manages the encapsulation of background table components
  • Ideas and practice of multi-language solution for Vue.js front-end project
  • 10 Best Practices for Building and Maintaining Large-Scale Vue.js Projects

<<:  Solve the problem of qt.qpa.plugin: Could not load the Qt platform plugin "xcb" in Qt under Ubuntu 18.04

>>:  How to solve the problem of not finding the password after decompressing the MySQL free installation version

Recommend

Basic HTML directory problem (difference between relative path and absolute path)

Relative path - a directory path established based...

Complete steps to install mysql5.7 on Mac (with pictures and text)

I recently used a Mac system and was preparing to...

Detailed explanation of the pitfalls of MySQL 8.0

I updated MySQL 8.0 today. The first problem: Nav...

How to change the color of the entire row (tr) when the mouse stops in HTML

Use pure CSS to change the background color of a ...

How to use Greek letters in HTML pages

Greek letters are a very commonly used series of ...

Detailed explanation of common MySQL operation commands in Linux terminal

Serve: # chkconfig --list List all system service...

CSS performance optimization - detailed explanation of will-change usage

will-change tells the browser what changes will h...

Solve the problem of ugly blue border after adding hyperlink to html image img

HTML img produces an ugly blue border after addin...

MySQL 8.0.13 download and installation tutorial with pictures and text

MySQL is the most commonly used database. You mus...

Summary of methods to clear cache in Linux system

1) Introduction to cache mechanism In the Linux s...

MySQL isolation level detailed explanation and examples

Table of contents 4 isolation levels of MySQL Cre...

Best Practices Guide for MySQL Partitioned Tables

Preface: Partitioning is a table design pattern. ...