Vue组件入门(七)v-model与自定义事件

简介: Vue组件入门(七)v-model与自定义事件

前言


相信在我们日常的开发过程中,v-model这个指令的使用次数是很频繁的。他很方便的帮助我们省略了在input标签上书写的数据同步相关的代码,让我们更加关注于业务的实现。那你知道他这个指令帮助我们做了什么吗?以及他和自定义事件有什么关系呢?下面,我们来一点点的看看他的真相。


v-model


之前我们提到过,在input标签上书写v-model指令:


<input v-model="searchText" />
复制代码


他编译后,直接转换为如下代码:


<input
  :value="searchText"
  @input="searchText = $event.target.value"
/>
复制代码


但是,如果你是使用在组件上面的话,编译转换后的代码就不一样了:


<CustomCom
  :modelValue="title"
  @update:modelValue="val => title = val"
/>
复制代码


看到如上代码,我想你应该明白点什么了,如果想让他正常工作。你得干两件事:


  • 声明modelVal的props
  • 派发 update:modelValue 事件。


所以:


<!-- CustomCom.vue -->
<script setup>
defineProps(['modelValue'])
defineEmits(['update:modelValue'])
</script>
<template>
  <input
    :value="modelValue"
    @input="$emit('update:modelValue', $event.target.value)"
  />
</template>
复制代码


这样,我们就完成了在组件上实现v-model功能了。


<CustomCom v-model="title" />
复制代码


不过,对于v-model还有另一种实现方式,就是通过 computed的 getter 和 setter属性来完成事件的派发。也就是通过set方法触发相应的事件。


<!-- CustomCom.vue -->
<script setup>
import { computed } from 'vue'
const props = defineProps(['modelValue'])
const emit = defineEmits(['update:modelValue'])
const value = computed({
  get() {
    return props.modelValue
  },
  set(title) {
    emit('update:modelValue', title)
  }
})
</script>
<template>
  <input v-model="title" />
</template>
复制代码


通过 input 标签上的v-model 我们就很容易的触发,title这个计算属性的 set 方法,从而触发父组件进行数据更新。


然后通过 get方法实时获取父组件更新的数据的prop,完成数据的更新。

这样就形成了完整的闭环。

相关文章
|
2月前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
165 64
|
2月前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
61 8
|
2月前
|
JavaScript
在 Vue 3 中,如何使用 v-model 来处理自定义组件的双向数据绑定?
需要注意的是,在实际开发中,根据具体的业务需求和组件设计,可能需要对上述步骤进行适当的调整和优化,以确保双向数据绑定的正确性和稳定性。同时,深入理解 Vue 3 的响应式机制和组件通信原理,将有助于更好地运用 `v-model` 实现自定义组件的双向数据绑定。
|
2月前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
JavaScript 前端开发 UED
如何在 Vue 自定义组件中正确使用 v-model 进行数据的双向绑定?
如何在 Vue 自定义组件中正确使用 v-model 进行数据的双向绑定?
241 0
|
JavaScript 前端开发 算法
web前端面试高频考点——Vue组件间的通信及高级特性(多种组件间的通信、自定义v-model、nextTick、插槽)
web前端面试高频考点——Vue组件间的通信及高级特性(多种组件间的通信、自定义v-model、nextTick、插槽)
158 0
|
JavaScript
Vue:自定义v-model数据双向绑定
Vue:自定义v-model数据双向绑定
141 0
Vue:自定义v-model数据双向绑定
|
容器 JavaScript
Vue自定义v-model
版权声明:本文首发 http://asing1elife.com ,转载请注明出处。 https://blog.csdn.net/asing1elife/article/details/82811783 ...
1120 0
|
22天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
119 1
|
2天前
|
JavaScript 安全 API
iframe嵌入页面实现免登录思路(以vue为例)
通过上述步骤,可以在Vue.js项目中通过 `iframe`实现不同应用间的免登录功能。利用Token传递和消息传递机制,可以确保安全、高效地在主应用和子应用间共享登录状态。这种方法在实际项目中具有广泛的应用前景,能够显著提升用户体验。
22 8