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
PHPzavant
2023-05-17 20:19:041382parcourir

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

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

npm install mitt

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();

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

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

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

//接收传值
mitt.on("mittClick", (val) => {
    console.log(val)//数据数据数据
})

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>

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer