当前位置: 首页 > news >正文

在vue2中,v-model和.sync的区别

最近在封装一个弹窗组件时,用了比较复杂的逻辑去做显示和隐藏的逻辑,在查看同事的代码之后,才知道还有更简单的方法,自己已经忘了一些API.
popup组件里统一的template:

<div v-if='isShowPopup'>
// 弹窗内容
</div>

自己的方法

 data(){return {isShowPopup: false,}},methods: {showPopup() {this.isShowPopup = true},closePopup() {this.isShowPopup = false}}

在外部通过给popup组件绑定ref=‘xxx’,从而通过this.$refs.xxx.showPopup()/ closePopup() 实现显示和隐藏控制
同事的方法

// popup组件 props: {show: {type: Boolean,default: true},},computed: {isShowPopup: {get() {return this.show;},set(val) {this.$emit("update:show", val);}}},

在外部通过给popup组件绑定:show.sync=‘xxx’,从而通过this.xxx = true / false 实现显示和隐藏控制

从以上可以看到,同事的方法实现思路更加清晰,也比较符合官方文档的要求:
在这里插入图片描述
以上的意思总结:在某些情况下,我们可能需要对组件的一个prop值进行“双向绑定”。真正的双向绑定可能会产生维护问题,因为该变化的来源在父组件和子组件中都不明显。所以我们建议在子组件里以update:myPropName的模式发出事件,父组件可以以:myPropName.sync=‘xxxx’ 绑定在子组件里。
代码比较如下:
传统的方法

<text-document:title="doc.title"@updateTitle="doc.title = $event"
></text-document>

在text-document的子组件里以 this.$emit(“updateTitle”, xxx);发出
新的方法:

<text-documentv-bind:title="doc.title"v-on:update:title="doc.title = $event"
></text-document>

可简写成

<text-document v-bind:title.sync="doc.title"></text-document>

在text-document的子组件里以 this.$emit(“update:title”, xxx);发出

可以看到在新的方法里,用户可通过.sync 和 update: 就可知道父子之间的传值关系
喜欢思考的小伙伴的,可能发现v-model不也是双向绑定吗,是不是里面也是.sync 和 update: 的一种实现?
没错!

<ChildComponent v-model="pageTitle" />// would be shorthand for<ChildComponent :value="pageTitle" @input="pageTitle = $event" />

所以也可以写成:

<ChildComponent v-bind:value.sync="pageTitle" />

v-model默认是使用value作为prop,input作为事件,如果想改的话,可以借助于model,

Vue.component('base-checkbox', {model: {prop: 'checked',event: 'change'},props: {checked: Boolean},template: `<inputtype="checkbox"v-bind:checked="checked"v-on:change="$emit('change', $event.target.checked)">`
})

需要注意的是,你仍然需要在组件的props选项中声明 checked

更多细节可参考官方文档:https://v2.vuejs.org/v2/guide/components-custom-events#sync-Modifier

http://www.lryc.cn/news/184879.html

相关文章:

  • nginx 配置
  • 【计算机视觉|人脸建模】学习从图像中回归3D面部形状和表情而无需3D监督
  • Linux系统之部署h5ai目录列表程序
  • Java-Exception
  • C++并发与多线程(2) | 线程运行开始和结束的基本方式
  • vue3前端开发-flex布局篇
  • 网络是什么?(网络零基础入门篇)
  • 【JavaEE】线程安全的集合类
  • 【C++算法】is_partitioned、partition_copy和partition_point
  • MyBatis(JavaEE进阶系列4)
  • 『力扣每日一题15』:买卖股票的最佳时机
  • Java中栈实现怎么选?Stack、Deque、ArrayDeque、LinkedList(含常用Api积累)
  • 雷达分辨率单元、单向/双向雷达方程、天气雷达方程简介
  • RabbitMQ之Fanout(扇形) Exchange解读
  • Redisson—分布式集合详述
  • 开发做前端好还是后端好?这是个问题!
  • 运行huggingface Kosmos2报错 nameerror: name ‘kosmos2tokenizer‘ is not defined
  • 吃鸡玩家必备神器!一站式提升战斗力、分享干货!
  • 【maven】idea中基于maven-webapp骨架创建的web.xml问题
  • 【算法题】2034. 股票价格波动
  • APSIM模型】作物模型应用案例
  • io_uring之liburing库安装
  • Python WebSocket自动化测试:构建高效接口测试框架!
  • MySQL数据库——SQL优化(1)-介绍、插入数据、主键优化
  • Flink---10、处理函数(基本处理函数、按键分区处理函数、窗口处理函数、应用案例TopN、侧输出流)
  • 多种方案教你彻底解决mac npm install -g后仍然不行怎么办sudo: xxx: command not found
  • 斐波那契数列 JS
  • IP 地址的分类
  • CDN网络基础入门:CDN原理及架构
  • 李沐深度学习记录2:10多层感知机