recherche

Maison  >  Questions et réponses  >  le corps du texte

javascript - Un composant enfant déclenche un événement personnalisé du composant parent, mais le composant parent ne répond pas.

Ce qui suit est un sous-composant @change='showChange' est un événement de sous-composant
Le modèle suivant est enregistré en tant que composant de type commande

<template>
<select name="dType" class="form-control" v-el:select @change='showChange'>
      <option value="" v-if="type=='selectAll'">全部</option>
      <option v-for="branch in branchList" :value="branch.id" track-by="$index">
        {{branch.name}}
      </option>
  </select>
</template>

Les méthodes suivantes sont des sous-composants :

        showChange(event) {
            for (let branch of this.branchList) {
                if (branch['id'] === event.target.value) {
                    this.$emit('showChange',branch['prefix']);
                }
            }

Ce qui suit est le composant parent

<order-type @showChange='alert(2)'></order-type>        

Mais alert(2) n'est pas exécuté

大家讲道理大家讲道理2758 Il y a quelques jours1049

répondre à tous(3)je répondrai

  • 女神的闺蜜爱上我

    女神的闺蜜爱上我2017-07-05 11:05:26

    Vous venez de l'écrire comme ça, n'est-ce pas ?

    <order-type @showChange='alertFun'></order-type>     
    父组件有一个方法
    methods: {
        alertFun () {
            alert(2)
        }
    }

    Ce qui doit être transmis ici est un nom de fonction de la méthode du composant parent au lieu d'écrire directement alert(2)

    répondre
    0
  • 女神的闺蜜爱上我

    女神的闺蜜爱上我2017-07-05 11:05:26

    Cela devrait être le problème
    <option v-for="branch in branchList" :value="branch.id" track-by="$index">
    La boucle for in object obtient l'index, pas la valeur, donc branch.id ne peut pas être obtenu, il peut être modifié en for of

    répondre
    0
  • 伊谢尔伦

    伊谢尔伦2017-07-05 11:05:26

    Ce qui suit est un sous-composant @change='showChange' est un événement de sous-composant
    Le modèle suivant est enregistré en tant que composant de type commande

    <template>
    <select name="dType" class="form-control" v-el:select @change:parentChage='showChange'>

      <option value="" v-if="type=='selectAll'">全部</option>
      <option v-for="branch in branchList" :value="branch.id" track-by="$index">
        {{branch.name}}
      </option>

    </select>
    </template>

    Les méthodes suivantes sont des sous-composants :

        showChange(event) {
            for (let branch of this.branchList) {
                if (branch['id'] === event.target.value) {
     /注意此行的修改/               this.$emit('parentChage',branch['prefix']);
                }
            }
            
            
            
    以下是父组件
    <order-type @showChange='alert(2)'></order-type>        
            
     但alert(2) 并未执行 

    répondre
    0
  • Annulerrépondre