Home > Web Front-end > Vue.js > How to use props and emit in Vue3

How to use props and emit in Vue3

WBOY
Release: 2023-05-26 18:13:15
forward
1898 people have browsed it

Function: The parent component passes data downward to the child component through props;

Usage: When a type of component needs to be used multiple times, each call is only different in a specific place, just like A personal profile form, the information filled in by the person is different every time, but the structure is the same.

Usage 1 (simple acceptance without specifying the type):

Introduce the sub-component into the parent component, pass the parameters through the label attribute of the sub-component, and define a props option in the sub-component to receive it When using it, please note that there is no need to define it in advance in the subcomponent outside of props.

How to use props and emit in Vue3

How to use props and emit in Vue3

How to use props and emit in Vue3

How to use props and emit in Vue3

##You can see above that the age passed in is a string type. If you want the passed in value to automatically increase by 1, you cannot add 1 when using the subcomponent. As shown in the figure below, it will become String addition 241

How to use props and emit in Vue3

How to use props and emit in Vue3

The correct solution is to use v-bind for dynamic binding when the parent component passes parameters. Defined, or you can use a colon: (short form), the function is to run the expression inside the quotation marks and return the running result, as shown in the figure below

How to use props and emit in Vue3

How to use props and emit in Vue3

Usage 2 (accept simultaneous type restrictions):

If the parameter type passed in is inconsistent with the specified type, the type passed in will take precedence and a warning will be issued.

How to use props and emit in Vue3

How to use props and emit in Vue3

Usage 3 (accept simultaneous type restriction default value specification):

There are two options after specifying the type , one is to specify whether it is necessary, and the other is the default value when not passed

How to use props and emit in Vue3

How to use props and emit in Vue3##Note:

is passed in props The element cannot be changed, otherwise an error will be reported. If you need to modify it, you should use a new variable to accept it and then modify it, as shown in the figure below. Because the priority of props is higher than return, the content of this.age will be prepared in advance. Good

In addition, after testing, this method can only be used in data and cannot be used in setup

How to use props and emit in Vue3emit use

There are two parameters props and context in setup

As shown in the figure below, props is the information passed by the parent component to the child component as mentioned above, as shown in the figure below

How to use props and emit in Vue3

How to use props and emit in Vue3Now the focus is on emit, emit is a thing in context

Function: used to trigger binding in the parent component function and can pass parameters back to the parent component

As shown in the configuration in the parent component APP.vue, a function xxx is bound to the sub-component tag and passed A parameter xxx1 is given to the child component. And the bound function xxx1 also has a parameter to be entered.

How to use props and emit in Vue3

How to use props and emit in Vue3 Now come to the sub-component. A button is bound to an event in the sub-component to trigger the event of the parent component. xxx1 and passed a string " " back,

How to use props and emit in Vue3

How to use props and emit in Vue3 Finally got the following effect, every time the button in the sub-component StDent is clicked , a string attribute in the parent component will automatically add two and display them

How to use props and emit in Vue3

emit summary: After the above example, we only need to know that emit is a function that allows child components to trigger parent components.

The above is the detailed content of How to use props and emit in Vue3. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:yisu.com
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
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template