- 父组件向子组件传值
1.
<script type="text/javascript"> // 创建 Vue 实例,得到 ViewModel var vm = new Vue({ el: '#app', data: { msg: '这是父组件中的消息' }, components: { son: { template: '<h1>这是子组件 --- {{finfo}}</h1>', props: ['finfo'] } } }); </script>
2.
<div id="app"> <son :finfo="msg"></son> </div>
- 子组件向父组件传值
<div id="app"> <!-- 引用父组件 --> <son @func="getMsg"></son> </div> <script type="text/javascript"> // 子组件的定义方式 Vue.component('son', { template:`
<div> <input type="button" value="向父组件传值" @click="sendMsg" /> </div>
`, // 组件模板Id methods: { sendMsg() { // 按钮的点击事件 this.$emit('func', 'OK'); // 调用父组件传递过来的方法,同时把数据传递出去 } } }); // 创建 Vue 实例,得到 ViewModel var vm = new Vue({ el: '#app', data: {}, methods: { getMsg(val){ // 子组件中,通过 this.$emit() 实际调用的方法,在此进行定义 alert(val); } } }); </script>
- 子组件中 data 和 props 的区别
子组件中的data数据,不是通过父组件传递的是子组件私有的,是可读可写的;
子组件中的所有 props中的数据,都是通过父组件传递给子组件的,是只读的;
- 关于Vue 属性 watch,computed和methods之间的对比
-
-
methods
方法表示一个具体的操作,主要书写业务逻辑; -
watch
一个对象,键是需要观察的表达式,值是对应回调函数。主要用来监听某些特定数据的变化,从而进行某些具体的业务逻辑操作;可以看作是computed
和methods