首頁 >web前端 >js教程 >vue子父元件互相傳遞資料(附程式碼)

vue子父元件互相傳遞資料(附程式碼)

php中世界最好的语言
php中世界最好的语言原創
2018-06-07 10:48:071344瀏覽

這次帶給大家vue子父元件互相傳遞資料(附程式碼),vue子父元件互相傳遞資料的注意事項有哪些,下面就是實戰案例,一起來看一下。

這裡講解一下子元件傳遞值給父元件的常用方式。這裡透過一個加減法的實例向大家說明一下,這個的原理。

如下圖所示:

當沒有任何動作的時候父元件的值是0

vue子父元件互相傳遞資料(附程式碼)

#當點選加號以後父元件的值是1

vue子父元件互相傳遞資料(附程式碼)

當點選減號以後父元件的值是減一變成0

vue子父元件互相傳遞資料(附程式碼)

具體代碼我直接貼出來,剛出爐的代碼。

nbsp;html>


  <meta>
  <meta>
  <meta>
  <title>子组件将数据传递给父组件</title>
  <script></script>

<script>
//定义一个组件
Vue.component(&#39;counter&#39;, {
 template: &#39;\
    <p style="background:#eee;width: 238px;">\
        <p>这里是子组件里面的内容!\
        <p style="margin-top:20px">\
        <p>\
          <span style="margin-right:20px;display:inline-block;">加法运算<button @click="incrementCounter">+\
        \
        <p>\
          <span style="margin-right:20px;margin-top:20px;display:inline-block;">减法运算<button @click="deleteCounter">-\
        \
    \
  &#39;,
 data: function () {
  return {
   counter: 0
  }
 },
 methods: {
  incrementCounter: function () {
   this.counter += 1;
   this.$emit(&#39;increment&#39;,1);
  },
  deleteCounter: function () {
   this.counter -= 1;
   this.$emit(&#39;increment&#39;,2);
  }
 }
})
//执行一个组件
window.onload = function(){
  var app = new Vue({
    el: &#39;#app&#39;,
    data: {
      total: 0
    },
    methods:{
      incrementTotal: function (val) {
        if(val==1){
          this.total += 1;
        }else{
          if(this.total<=0){
            this.total = 0;
          }else{
            this.total -= 1;
          }
        }
      }
    }
  })
}
</script>

  <p>
    </p><p>这里是父组件里面的内容!</p>    
    <p>子组件传递的值:<b>{{ total }}</b></p>
    <counter></counter>
  

我相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

vue.js element-ui做出選單樹形結構

##如何操作Vue做出proxy代理

以上是vue子父元件互相傳遞資料(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn