当前位置:首页 > VUE

vue实现双向

2026-01-13 01:42:21VUE

Vue 实现双向绑定的方法

Vue 主要通过 v-model 指令实现双向绑定,适用于表单元素或自定义组件。以下是几种常见实现方式:

表单元素的双向绑定

在表单元素(如 inputtextareaselect)上直接使用 v-model,Vue 会自动处理值的同步。

<input v-model="message" placeholder="Edit me">
<p>Message is: {{ message }}</p>

自定义组件的双向绑定

自定义组件需通过 model 选项和 $emit 事件实现双向绑定。

  1. 父组件使用 v-model

    <custom-input v-model="searchText"></custom-input>
  2. 子组件通过 props 接收值并触发 input 事件:

    props: ['value'],
    template: `
    <input
     :value="value"
     @input="$emit('input', $event.target.value)"
    >
    `

使用 .sync 修饰符

Vue 支持通过 .sync 修饰符实现多个 props 的双向绑定。

父组件:

<child-component :title.sync="pageTitle"></child-component>

子组件触发更新:

this.$emit('update:title', newValue)

计算属性的双向绑定

通过计算属性的 getset 方法实现复杂逻辑的双向绑定。

vue实现双向

computed: {
  fullName: {
    get() {
      return this.firstName + ' ' + this.lastName
    },
    set(newValue) {
      const names = newValue.split(' ')
      this.firstName = names[0]
      this.lastName = names[names.length - 1]
    }
  }
}

注意事项

  • 双向绑定可能引发数据流难以追踪的问题,建议在必要时使用。
  • 自定义组件的 v-model 默认利用 value prop 和 input 事件,可通过 model 选项修改。
  • Vue 3 中 v-model 默认使用 modelValue prop 和 update:modelValue 事件。

标签: 双向vue
分享给朋友:

相关文章

vue实现复选

vue实现复选

Vue 实现复选框 在 Vue 中实现复选框可以通过 v-model 指令绑定数据,同时结合 input 元素的 type="checkbox" 属性来实现。以下是几种常见的实现方式: 单个复选框…

vue实现导出

vue实现导出

Vue 实现导出功能的方法 在 Vue 项目中实现导出功能通常涉及将数据导出为 Excel、CSV 或其他格式。以下是几种常见的实现方式: 使用 xlsx 库导出 Excel 安装 xlsx 库:…

vue实现selectable

vue实现selectable

Vue 实现可选择的 Select 组件 在 Vue 中实现一个可选择的 Select 组件,可以通过以下几种方式: 使用原生 HTML select 元素 <template>…

vue实现curd

vue实现curd

Vue实现CRUD操作 初始化Vue项目 使用Vue CLI创建新项目,安装必要依赖如axios用于HTTP请求 vue create crud-demo cd crud-demo npm inst…

vue实现 页面

vue实现 页面

Vue 实现页面的核心方法 创建 Vue 项目 使用 Vue CLI 或 Vite 快速初始化项目。Vue CLI 是官方脚手架工具,适合传统项目;Vite 提供更快的现代构建体验。 npm cre…

vue实现文章滚动

vue实现文章滚动

Vue 实现文章滚动效果 使用 CSS 实现基础滚动 通过 CSS 的 overflow 和 height 属性控制滚动区域,适用于静态内容滚动。在 Vue 模板中定义固定高度的容器,内容超出后自动滚…