Detailed explanation of the case of Vue child component calling parent component method

Detailed explanation of the case of Vue child component calling parent component method

1. Call the parent component method directly through this.$parent.event in the child component

<!-- Parent component -->
<template>
	<div>
		<child></child>
	</div>
</template>
<script>
import child from '~/components/dam/child';
export default {
	components:
		child
	},
	methods: {
		fatherMethod() {
			console.log('test');
		}
	}
};
</script>
<!-- Child Component -->
<template>
  <div>
    <button @click="childMethod()">Click</button>
  </div>
</template>
<script>
  export default {
    methods: {
      childMethod() {
        this.$parent.fatherMethod();
      }
    }
  };
</script>

2. Use $emit in the child component to trigger an event to the parent component, and the parent component listens to this event

<!-- Parent component -->
<template>
	<div>
		<child @fatherMethod="fatherMethod"></child>
	</div>
</template>
<script>
import child from '~/components/dam/child';
export default {
	components:
		child
	},
	methods: {
		fatherMethod() {
			console.log('test');
		}
	}
};
</script>
<!-- Child Component -->
<template>
	<div>
		<button @click="childMethod()">Click</button>
	</div>
</template>
<script>
export default {
	methods: {
		childMethod () {
			this.$emit('fatherMethod');
		}
	}
};
</script>

3. The parent component passes the method to the child component and calls the method directly in the child component

<!-- Parent component -->
<template>
	<div>
		<child :fatherMethod="fatherMethod"></child>
	</div>
</template>
<script>
import child from '~/components/dam/child';
export default {
	components:
		child
	},
	methods: {
		fatherMethod() {
			console.log('test');
		}
	}
};
</script>
<!-- Child Component -->
<template>
	<div>
		<button @click="childMethod()">Click</button>
	</div>
</template>
<script>
export default {
	props: {
		fatherMethod: {
			type: Function,
			default: null
		}
	},
	methods: {
		childMethod () {
			if (this.fatherMethod) {
				this.fatherMethod();
			}
		}
	}
};
</script> 

This concludes this article about the detailed case of Vue child component calling parent component method. For more relevant Vue child component calling parent component method content, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Detailed example of how to change the value of a child component by triggering an event in the Vue parent component
  • Vue parent component calls child component function implementation
  • Detailed explanation of the event of triggering child components by clicking buttons in parent components in Vue
  • How to call child component functions in vue parent component
  • Vue3.0 triggers the parent component function in the child component

<<:  Causes and solutions to the garbled character set problem in MySQL database

>>:  Linux Jenkins configuration salve node implementation process diagram

Recommend

Nginx access log and error log parameter description

illustrate: There are two main types of nginx log...

Nginx uses Lua+Redis to dynamically block IP

1. Background In our daily website maintenance, w...

Implementation of the login page of Vue actual combat record

Table of contents 1. Preliminary preparation 1.1 ...

Summary of some common writing methods that cause MySQL index failure

Preface Recently, I have been busy dealing with s...

Detailed explanation of mysql exists and not exists examples

Detailed explanation of mysql exists and not exis...

How to use JavaScript to get the most repeated characters in a string

Table of contents topic analyze Objects of use So...

Mysql database scheduled backup script sharing

BackUpMysql.sh script #!/bin/bash PATH=/bin:/sbin...

CentOS method to modify the default ssh port number example

The default ssh port number of Linux servers is g...

In-depth understanding of the use of CSS clear:both

clear:both is used to清除浮動This is the impression I...

Tutorial diagram of installing mysql8.0.18 under linux (Centos7)

1 Get the installation resource package mysql-8.0...

Embed codes for several older players

The players we see on the web pages are nothing m...