Vue3组件数据双向绑定

在Vue的组件中,我们可以使用props将父组件的数据传递给子组件,父组件中的数据发生变化后,子组件也会跟着改变,但是props是向下绑定的,就是说当子组件的数据发生变化时,父组件不会改变。

为了能够在子组件中修改父组件的数据,我们可以使用 v-model 对组件间的数据进行双向绑定,在父组件或子组件中进行数据修改时都会引起对方的数据变化。

下面介绍使用 v-model 进行数据双向绑定的使用。

基础用法

在使用数据双向绑定时,需要自定义一个组件:

javascript 复制代码
<!-- 子组件 -->

<template>
  <input v-model="value">
</template>

<script setup>

const value = defineModel()

</script>

<style lang='scss' scoped>

</style>

在子组件中,使用 const value = defineModel() 声明双向数据绑定,defineModel() 返回的是一个ref,可以像其他ref一样访问或修改。

同时,需要一个父组件调用子组件,并传递双向绑定的数据。

javascript 复制代码
<!-- 父组件 -->

<template>
  <p>{{ value }}</p>
  <Child v-model="value"></Child>
</template>

<script setup>
import { ref } from 'vue';
import Child from '../../components/TestChild/index.vue'

const value = ref('abcde')

</script>

<style lang='scss' scoped>

</style>

在子组件上使用 v-model 将父组件的value与子组件双向绑定,子组件输入框修改时,父组件的value会一起改变。

v-model 的参数

组件上的 v-model 可以接收一个参数。同时,在子组件中,使用字符串传递给 defineModel() 以支持相应的参数。

javascript 复制代码
<!-- 子组件 -->

<template>
  <input v-model="value">
</template>

<script setup>

const value = defineModel('value')

</script>

<style lang='scss' scoped>

</style>
javascript 复制代码
<!-- 父组件 -->

<template>
  <p>{{ value }}</p>
  <Child v-model:value="value"></Child>
</template>

<script setup>
import { ref } from 'vue';
import Child from '../../components/TestChild/index.vue'

const value = ref('abcde')

</script>

<style lang='scss' scoped>

</style>
多个 v-model 绑定

在 v-model 的参数的基础上,我们可以单个组件实例上创建多个 v-model 双向绑定。

只需使用不同的参数便可以实现多个数据双向绑定。

javascript 复制代码
<!-- 子组件 -->

<template>
  <input v-model="value1">
  <input v-model="value2">
</template>

<script setup>

const value1 = defineModel('value1')
const value2 = defineModel('value2')

</script>

<style lang='scss' scoped>
  input {
    display: block;
  }
</style>
javascript 复制代码
<!-- 父组件 -->

<template>
  <p>{{ value1 }}</p>
  <p>{{ value2 }}</p>
  <Child 
  v-model:value1="value1"
  v-model:value2="value2"
  ></Child>
</template>

<script setup>
import { ref } from 'vue';
import Child from '../../components/TestChild/index.vue'

const value1 = ref('abcde')
const value2 = ref('sdvhj')

</script>

<style lang='scss' scoped>

</style>

结果:

相关推荐
DaqunChen28 分钟前
全栈开发的演变:从LAMP到MEAN再到现代JavaScript
开发语言·javascript·ecmascript
Camellia-lon32 分钟前
jQuery购物车实现:从入门到精通
前端·javascript·jquery
Mintopia35 分钟前
一套能落地的"模块拆分"方法:不靠经验也能做对
前端
禅思院37 分钟前
从术到道:构建企业级异步组件加载方案的设计哲学与实现精要
前端·vue.js·架构
哈罗哈皮38 分钟前
玩转OpenLayers主题色修改,打造独一无二的个性化地图
前端
糯米团子74940 分钟前
react速通-1
javascript·react.js
yuanpan44 分钟前
Python 开发一个简单演示网站:用 Flask 把脚本能力扩展成 Web 应用
前端·python·flask
IT_陈寒1 小时前
Python的GIL把我CPU跑满时我才明白并发不是这样玩的
前端·人工智能·后端
小江的记录本1 小时前
【分布式】分布式系统核心知识体系:CAP定理、BASE理论与核心挑战
java·前端·网络·分布式·后端·python·安全
freewlt1 小时前
企业级前端性能监控体系:从Core Web Vitals到实时大盘实战
前端