Vue2系列 — 修饰符.sync

.sync 修饰符以前存在于 Vue1.0 版本里,后来在2.0版本中移除了 .sync 修饰符。

但是在 2.0 发布之后的实际应用中,发现 .sync 还是有其适用之处,比如在开发可复用的组件库时。我们需要做的只是让子组件改变父组件状态的代码更容易被区分

从 2.3.0 起重新引入了 .sync 修饰符,但是这次它只是作为一个编译时的语法糖存在。它会被扩展为一个自动更新父组件属性的 v-on 监听器。

1 使用情景

需要父组件给子组件传值

子组件通过 emit 改变该值

2 原写法:

v-bind 传值 money 给子组件

并绑定事件 update:money 改变 money 值

父组件:
javascript 复制代码
<template>
  <div class="app">
    <Child
      v-bind:money="total" 
      v-on:update:money="money = $event"
    />
  </div>
</template>
子组件:
javascript 复制代码
<template>
  <div class="child">
    {{ money }}
    <button @click="$emit('update:money', money - 100)">
    </button>
  </div>
</template>

<script>
export default {
  props: ["money"],
};
</script>

3 为了方便起见,为这种模式提供一个缩写,即 .sync 修饰符:

示例:https://codesandbox.io/s/white-glade-xhj86?file=/src/App.vue

父组件:
html 复制代码
<template>
  <div class="app">
    <Child v-bind:money.sync="total" />
    <!--  或 <Child :money.sync="total" />   -->
  </div>
</template>

4 需要注意的是

  • 带有 .sync 修饰符的 v-bind 不能和表达式一起使用 (例如 v-bind:title.sync="doc.title +
    '!'" 是无效的)。取而代之的是,你只能提供你想要绑定的 property 名,类似 v-model。
  • 当我们用一个对象同时设置多个 prop 的时候,也可以将这个 .sync 修饰符和 v-bind 配合使用:
html 复制代码
<text-document v-bind.sync="doc"></text-document>

这样会把 doc 对象中的每一个 property (如 title) 都作为一个独立的 prop 传进去,然后各自添加用于更新的 v-on 监听器。

  • 将 v-bind.sync 用在一个字面量的对象上,例如 v-bind.sync="{ title: doc.title }",是无法正常工作的,因为在解析一个像这样的复杂表达式的时候,有很多边缘情况需要考虑。
相关推荐
宁雨桥9 分钟前
AI前端开发面试题分享
前端·人工智能·ai
亿元程序员9 分钟前
求求你别卷了,主管又转发你的文章到工作群了...我看了之后五味杂陈,决定卷个毛线!
前端
kyriewen1119 分钟前
你的前端滤镜慢得像PPT?用Rust+WebAssembly,一秒处理4K图
开发语言·前端·javascript·设计模式·rust·ecmascript·powerpoint
QD_ANJING29 分钟前
建议5月的Web前端开发都去飞书上准备面试...
前端·人工智能·面试·职场和发展·前端框架·状态模式·ai编程
萤萤七悬37 分钟前
【人工智能训练师3级】考试准备(2026)三、实操题1.1.3-3.2.5
前端·数据库·人工智能
yqcoder42 分钟前
JavaScript 深拷贝:如何彻底切断引用关联?
开发语言·前端·javascript
镜宇秋霖丶9 小时前
2026.5.6@霖宇博客制作中遇见的问题
前端·javascript·vue.js
计算机专业码农一枚9 小时前
微信小程序 uniapp+vue高校社团管理
vue.js·微信小程序·uni-app
吴声子夜歌10 小时前
Vue3——TypeScript基础
javascript·typescript