Vue中子傳父($emit)


子組件代碼:

<template id="cpn1">
    <div>
      <button v-for="item in categories"
              @click="btnclick(item)">
        {{item.name}}
      </button>
    </div>
  </template>

  

 
         
  const cpn = {
      template:'#cpn1',
      data(){
        return{
          categories:[
            {id:'aaa',name:'家電'},
            {id:'bbb',name:'玩具'},
            {id:'ccc',name:'彩妝'},
            {id:'ddd',name:'家具'},
          ]
        }
      },
      methods:{
        btnclick(item){
          // 子組件向父組件發射自定義事件(自定義事件名字,自定義事件參數)
          this.$emit('itemclick',item)
        }
      }
    }
 

父組件代碼:

<!-- 父組件模板 -->
  <div id="app">
    <!-- 子組件自定義的事件 = 父組件定義的事件 -->
    <mycpn @itemclick="cpnclick"></mycpn>
  </div>

  

 const app = new Vue({
      el:"#app",
      data:{
        message:'你好啊',
        movies:['小時代','前任','匆匆那年','蠟筆小新','大頭娃娃']
      },
      components:{
        mycpn:cpn,
      },
      methods:{
        cpnclick(item){
         console.log(item.id)
        }
      }
    })

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM