Vue component value transfer method: 1. Use props to pass data. The parent component passes the data to the child component through HTML attributes, and the child component receives the passed data through props; 2. Use $emit Trigger events to transfer data. The sub-component uses $emit to trigger custom events. The parent component uses v-on to listen to the sub-component custom events. 3. Use provide/inject to transfer values across levels. The parent component provides data through provide, and the sub-component Use inject to receive data.
#The operating environment of this tutorial: Windows 10 system, dell g3 computer.
Value transfer between Vue components can be achieved in three ways: props, $emit and provide/inject.
Use props to pass data:
Pass data to the child component through HTML attributes in the parent component. Child components receive data passed by parent components through props.
Parent component:
<template> <div> <ChildComponent :message="message"/> </div> </template> <script> import ChildComponent from 'ChildComponent.vue'; export default { components: { ChildComponent }, data() { return { message: 'Hello' } } } </script>
Child component:
<template> <div> {{ message }} </div> </template> <script> export default { props: { message: String } } </script>
Use $emit to trigger events to pass data:
In child components Use $emit to trigger custom events and pass the data to be passed as parameters. The parent component uses v-on to listen to the custom events of the child component and obtain the passed data.
Parent component:
<template> <div> <ChildComponent v-on:custom-event="updateData"/> </div> </template> <script> import ChildComponent from 'ChildComponent.vue'; export default { components: { ChildComponent }, data() { return { message: '' } }, methods: { updateData(data) { this.message = data; } } } </script>
Child component:
<template> <div> <button @click="updateMessage">Update Message</button> </div> </template> <script> export default { methods: { updateMessage() { this.$emit('custom-event', 'New Message'); } } } </script>
Use provide/inject for cross-level value transfer:
In the parent Provide data through provide in the component, and then use inject to receive the data in the child component.
Parent component:
<template> <div> <ChildComponent /> </div> </template> <script> import ChildComponent from 'ChildComponent.vue'; export default { components: { ChildComponent }, provide() { return { message: 'Hello' } } } </script>
Child component:
<template> <div> {{ message }} </div> </template> <script> export default { inject: ['message'] } </script>
The above are the three ways for Vue components to pass values. According to specific scenarios and needs, you can choose a suitable method to transfer data between components.
The above is the detailed content of What are the ways to pass values in vue components?. For more information, please follow other related articles on the PHP Chinese website!

vue中props可以传递函数;vue中可以将字符串、数组、数字和对象作为props传递,props主要用于组件的传值,目的为了接收外面传过来的数据,语法为“export default {methods: {myFunction() {// ...}}};”。

本篇文章带大家聊聊vue指令中的修饰符,对比一下vue中的指令修饰符和dom事件中的event对象,介绍一下常用的事件修饰符,希望对大家有所帮助!

如何覆盖组件库样式?下面本篇文章给大家介绍一下React和Vue项目中优雅地覆盖组件库样式的方法,希望对大家有所帮助!

react与vue的虚拟dom没有区别;react和vue的虚拟dom都是用js对象来模拟真实DOM,用虚拟DOM的diff来最小化更新真实DOM,可以减小不必要的性能损耗,按颗粒度分为不同的类型比较同层级dom节点,进行增、删、移的操作。

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

Notepad++7.3.1
Easy-to-use and free code editor

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.