码迷,mamicode.com
首页 > Web开发 > 详细

vuejs父子组件的数据传递

时间:2018-09-15 12:19:35      阅读:142      评论:0      收藏:0      [点我收藏+]

标签:形式   function   而且   基础   vue   事件   var   控制台   ack   

在vue中,父组件往子组件传递参数都是通过属性的形式来传递的
<div id=‘root‘>
  <counter :count = ‘1‘></counter>
  <counter :count = ‘2‘></counter>
</div>

<script>
var counter = {
  props:[count],
    template:<div>{{count}}</div>
  }
  var vm = new Vue({
    el:#root,
    components:{
      counter: counter
    }
})
</script>

 

 

需求,在子组件被点击的时候+1,我们可能会这么写
var counter = {
  props:[‘count‘],
  template:‘<div @click="handleClick">{{count}}</div>‘,
  methods:{
    handleClick:function(){
      this.count ++
    }
  }
}
这个时候页面上看上去是正常的,但是控制台会报错,为什么呢?
vue中有个单向数据流的概念,也就是父组件可以向子组件传递参数,通过属性传,传递的参数可以随便的进行修改,但是反过来,子组件绝对不能去修改父组件传递过来的参数,只能用这个内容,但是不能修改这个内容
之所以vue中有这个单向数据流的概念,原因在于,一旦子组件这个接收的数据并不是基础类型的数据,而是一个引用数据的时候,在子组件改变了数据,又可能接收的这个内容还被其他的组件所使用,这样不仅仅改了自身的数据,还会对其他对组件造成影响,所以vue中有个单向数据流,子组件不能改变父组件传递过来对数据

 

那么,这里确实要改变这个count的值,现在不让我改,那要怎么实现这个功能呢?
var counter = {
  props:[‘count‘],
  data:function(){
    return {
      number:this.count
    }
  },
  template:‘<div @click="handleClick">{{number}}</div>‘,
  methods:{
    handleClick:function(){
      this.number ++
    }
  }
}
这样实现,将父组件传递过来的参数赋值给子组件的number,再使用子组件自己的数据的时候,是可以进行更改的,而且也不会影响到父组件的数据



子组件如何向父组件传递参数
通过事件触发的方式,$emit
<div id=‘root‘>
  <counter :count = ‘3‘ @change = ‘handleChange‘></counter>
  <counter :count = ‘2‘ @change = ‘handleChange‘></counter>
  <div>{{total}}</div>
</div>


<script>
var counter = {
  props:[count],
  data:function(){
    return {
      number:this.count
    }
  },
  template:<div @click="handleClick">{{number}}</div>,
  methods:{
    handleClick:function(){
      this.number += 2;
      this.$emit(change,2);
    }
  }
}
var vm = new Vue({
  el:#root,
  data:{
    total:5
  },
  components:{
    counter: counter
  },
  methods:{
    handleChange:function(step){
      this.total += step;
    }
  }
})

 

 

vuejs父子组件的数据传递

标签:形式   function   而且   基础   vue   事件   var   控制台   ack   

原文地址:https://www.cnblogs.com/wzndkj/p/9650398.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!