在Vue组件中,v-model指令可以用来实现双向数据绑定。它用于将组件的属性和父组件中的数据进行双向绑定,使得当属性的值改变时,父组件中的数据也会相应地改变,并且当父组件中的数据改变时,属性的值也会相应地改变。
目录
v-model
表单类组件使用v-model简化绑定
化简前
化简后
v-model
原理:v-model本质上是一个语法糖(语法简写)。例如应用在输入框(不同元素的原表示不同,所以这里只举例输入框)上,就是value属性和input事件的合写。
作用:提供数据的双向绑定
- 数据发生改变,页面会自动变:value
 - 页面输入改变,数据会自动变@input
 
注意:$event用于在模板中,用于获取事件的形参

App.vue
<template>
  <div class="app">
    <input type="text" v-model="msg1" />
    <br />
    <input type="text" :value="msg2" @input="msg2 = $event.target.value" />
  </div>
</template>
<script>
export default {
  data() {
    return {
      msg1: '',
      msg2: '',
    }
  },
}
</script>
<style>
</style> 
表单类组件使用v-model简化绑定
- 父传子:数据由父组件props传递过来,v-model拆解绑定数据
 - 子传父:监听输入,子传父传值给父组件修改
 
父组件使用,子组件封装
化简前

化简后
- 子组件中,props通过value接收,事件触发input
 - 父组件中,v-model给组件直接绑数据(:value+@input)
 

 
BaseSelect.vue
<template>
  <div>
    <select :value="value" @change="selectCity">
      <option value="101">北京</option>
      <option value="102">上海</option>
      <option value="103">武汉</option>
      <option value="104">广州</option>
      <option value="105">深圳</option>
    </select>
  </div>
</template>
<script>
export default {
  props: {
    value: String,
  },
  methods: {
    selectCity(e) {
      this.$emit('input', e.target.value)
    },
  },
}
</script>
<style>
</style> 
App.vue
<template>
  <div class="app">
    <BaseSelect
      v-model="selectId"
    ></BaseSelect>
  </div>
</template>
<script>
import BaseSelect from './components/BaseSelect.vue'
export default {
  data() {
    return {
      selectId: '102',
    }
  },
  components: {
    BaseSelect,
  },
}
</script>
<style>
</style> 
main.js
import Vue from 'vue'
import App from './App.vue'
Vue.config.productionTip = false
new Vue({
  render: h => h(App),
}).$mount('#app')
 
                

















