Maison > interface Web > Voir.js > Comment résoudre le problème du transfert de valeur mutuelle entre les sous-composants de vue3

Comment résoudre le problème du transfert de valeur mutuelle entre les sous-composants de vue3

PHPz
Libérer: 2023-05-17 20:19:04
avant
1389 Les gens l'ont consulté

Les sous-composants Vue3 transfèrent des valeurs les uns aux autres

1. Référencez la bibliothèque tierce mitt

npm install mitt
Copier après la connexion

2 Créez un dossier utils sous le dossier src du projet et créez mitt.js dans utils Le code dans mitt. .js est le suivant :

import mitt from "mitt";
export default new mitt();
Copier après la connexion

3. Exemple : le composant A transmet la valeur au composant B

//在组件A中引入
import mitt from "@/utils/mitt";

//调用传值
mitt.emit("mittClick", "数据数据数据");
Copier après la connexion
//在组件B中引入
import mitt from "@/utils/mitt";

//接收传值
mitt.on("mittClick", (val) => {
    console.log(val)//数据数据数据
})
Copier après la connexion

vue Différents composants se transmettent des valeurs

Utilisez une instance Vue vide pour transmettre la valeur, transmettez simplement $emit, $ sur.

<!DOCTYPE html>
<html lang="zh-CN">
    <head>
        <title></title>
        <meta charset="utf-8">
        <script src="./main/vue.js"></script>
    </head>
    <body>
        <div id="demo">
            <!-- test code -->
            <custom-a></custom-a>
            <custom-b></custom-b>
            <!-- test code -->
        </div>
    </body>
    <script type="text/javascript">
    let bus = new Vue();
    Vue.component("custom-a", {
        template: &#39;<button @click="transValue">Click</button>&#39;,
        methods: {
            transValue: () => bus.$emit("transValue", "hello from a")
        }
    });
    Vue.component("custom-b", {
        template: &#39;<input :value="msg">&#39;,
        data: function() {
            return {
                msg: ""
            }
        },
        mounted() {
            bus.$on("transValue", msg => this.msg = msg)
        }
    });
    new Vue({
        el: "#demo"
    });
    </script>
</html>
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:yisu.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal