Vue 父組件往子組件傳遞方法


<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <script src="./lib/vue-2.4.0.js"></script>
</head>

<body>
  <div id="app">
    <!-- 父組件向子組件 傳遞 方法,使用的是 事件綁定機制; v-on, 
      當我們自定義了 一個 事件屬性之后,那么,子組件就能夠,通過某些方式,來調用 傳遞進去的 這個 方法了 -->
    <com2 @func123="show"></com2>
  </div>

  <template id="tmpl">
    <div>
      <h1>這是子組件</h1>
      <input type="button" value="這是子組件中的按鈕 - 點擊它,觸發 父組件傳遞過來的 func 方法" @click="myclick">
    </div>
  </template>

  <script>
    // 定義了一個字面量類型的 組件模板對象
    var com2 = {
      template: '#tmpl', // 通過指定了一個 Id, 表示 說,要去加載 這個指定Id的 template 元素中的內容,當作 組件的HTML結構
      data() {
        return {
          sonmsg: '子組件中data中的數據'
        }
      },
      methods: {
        myclick() {
          // 當點擊子組件的按鈕的時候,如何 拿到 父組件傳遞過來的 func 方法,並調用這個方法???
          //  emit 英文原意: 是觸發,調用、發射的意思
          // this.$emit('函數名稱', 參數, 參數) func123是
          this.$emit('func123', this.sonmsg)
        }
      }
    }
    // 創建 Vue 實例,得到 ViewModel
    var vm = new Vue({
      el: '#app',
      data: {
        datamsgFormSon: '父組件中的數據'
      },
      methods: {
        show(data) {
          alert('調用了父組件身上的 show 方法: --- ' + this.datamsgFormSon)
          this.datamsgFormSon = data
          alert('調用了父組件身上的 show 方法: --- ' + this.datamsgFormSon)
        }
      },
      components: {
        com2
      }
    });
  </script>
</body>

</html>

 


免責聲明!

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



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