vue 自定义组件 v-model双向绑定、 父子组件同步通信 侵立删

v-model 指令在表单控件元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。但是 Vue 是单项数据流,v-model 只是语法糖而已。v-bind只是个单向绑定

     v-model这个指令只能用在<input>, <select>,<textarea>这些表单元素上,所谓双向绑定,指的就是我们在js中的vue实例中的data与其渲染的dom元素上的内容保持一致,两者无论谁被改变,另一方也会相应的更新为相同的数据。这是通过设置属性访问器实现的。

1.在一般使用情况下,v-model为:

<input v-model="searchText">
  • 等价于
<input v-bind:value="searchText" v-on:input="searchText = $event.target.value">
  • 在组件中,v-model为:
<custom-input v-model="searchText"></custom-input>
  • 等价于
<custom-input v-bind:value="searchText" v-on:input="searchText = arguments[0]"></custom-input>
  • 一个组件上的 v-model 默认会利用名为 value 的 prop 和名为 input 的事件,但是像单选框、复选框等类型的输入控件可能会将 value 特性用于不同的目的。model 选项可以用来避免这样的冲突:
 
  1. Vue.component('base-checkbox', {
    
    model: {
    
    prop: 'checked',
    
    event: 'change'
    
    },
    
    props: {
    
    checked: Boolean
    
    },
    
    template: `
    
    <input
    
    type="checkbox"
    
    v-bind:checked="checked"
    
    v-on:click="$emit('change', $event.target.checked)"
    
    >
    
    `
    
    })
  • 相当于把value和input替换掉了
<base-checkbox v-bind:checked="checked" v-on:change="checked=arguments[0]"></base-checkbox>

父子组件通信,都是单项的,很多时候需要双向通信。方法如下:

  1、父组件使用:msg.sync="aa"  子组件使用$emit('update:msg', 'msg改变后的值xxx') 

  2、父组件传值直接传对象,子组件收到对象后可随意改变对象的属性,但不能改变对象本身。

  3、父组件使用: v-model 

  第一种曾经被废除过,由于维护成本的原因被删掉,但经过证实,确实有存在的意义,又被加上。

  第一种:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

父组件:

    <template>

  <div>

    <aa class="abc" :snycTest.sync="test" ></aa>

      {{'外面的值:' + test}}

    <button @click="fn">

      外面改变里面

    </button>

     

  </div>

</template>

<script>

import aa from './test.vue'

  export default {

    data () {

      return {

        test: ''

      }

    },

    methods: {

      fn () {

        this.test += 1

      }

    },

    components:{

      aa

    }

  }

</script>

  

复制代码

子组件:
 <template>
  <div>
    <ul>
      <li>{{'里面的值:'+ snycTest}}</li>
      <button @click="fn2">里面改变外面</button>
    </ul>
  </div>
</template>

<script>
  export default {
    props: {
      snycTest: ''
    },
    methods: {
      fn2 () {
        this.$emit('update:snycTest', this.snycTest+1) //这儿是关键 update:snycTest 自定义事件会告诉父组件将父组件的 test值改为this.snycTest+1,并传回给子组件。
} } } </script>

复制代码

v-model写法一:

复制代码

父组件:
 <template>
  <div>
    <aa class="abc" v-model="test" ></aa>  // 组件中使用v-model
      {{'外面的值:' + test}} // 这儿试验test与内部msg值为双向绑定关系
    <button @click="fn">
      外面改变里面
    </button>
    
  </div>
</template>

<script>
import aa from './test.vue'
  export default {
    data () {
      return {
        test: ''
      }
    },
    methods: {
      fn () {
        this.test += 1 
      }
    },
    components:{
      aa
    }
  }
</script>

复制代码

复制代码

子组件写法一:
<template>
  <div>
    <ul>
      <li>{{'里面的值:'+ msg}}</li>
      <button @click="fn2">里面改变外面</button>
    </ul>
  </div>
</template>

<script>
  export default {
    model: {    // 使用model, 这儿2个属性,prop属性说,我要将msg作为该组件被使用时(此处为aa组件被父组件调用)v-model能取到的值,event说,我emit ‘cc’ 的时候,参数的值就是父组件v-model收到的值。
      prop: 'msg',
      event: 'cc'
    },
    props: {
      msg: ''
    },
    methods: {
      fn2 () {
        this.$emit('cc', this.msg+2)
      }
    }
  }
</script> 
 

复制代码

v-model写法二

  父组件 <aa class="abc" v-model='test' ></aa> 。

复制代码

子组件
<template>
 <div>
    <ul>
      <li>{{'里面的值:'+ value}}</li> // 组件使用时有v-model属性,value初始传的‘what’ 不会被渲染,而是v-model绑定的test值被渲染,这儿value会被重新赋值为v-model绑定的test的值。
      <button @click="fn2">里面改变外面</button>
    </ul>
  </div>
</template>

<script>
  export default {
    props: {
      value: { // 必须要使用value
     default: '',
    },
    },

    methods: {
      fn2 () {
        this.$emit('input', this.value+2) // 这儿必须用input 发送数据,发送的数据会被父级v-model=“test”接受到,再被value=test传回来。
      }
    }
  }

复制代码

一般双向绑定用v-model写法一。

来源:https://www.cnblogs.com/gsgs/p/7294160.html 

猜你喜欢

转载自blog.csdn.net/qq_22167989/article/details/88556860