当前位置:首页 > VUE

vue 如何实现vmodel

2026-01-19 04:35:26VUE

Vue 中实现 v-model 的方法

v-model 是 Vue 中用于实现双向数据绑定的指令,通常用于表单元素。以下是实现 v-model 的几种方式:

在表单元素上使用 v-model

对于原生表单元素(如 inputtextareaselect),可以直接使用 v-model 绑定数据:

<template>
  <input v-model="message" placeholder="输入内容">
  <p>输入的内容是:{{ message }}</p>
</template>

<script>
export default {
  data() {
    return {
      message: ''
    }
  }
}
</script>

在自定义组件上使用 v-model

在自定义组件中,可以通过 model 选项或 Vue 2.6+ 的 v-model 语法糖实现双向绑定。

vue 如何实现vmodel

方法 1:使用 model 选项(Vue 2.x)

<template>
  <custom-input v-model="message"></custom-input>
</template>

<script>
export default {
  data() {
    return {
      message: ''
    }
  },
  components: {
    'custom-input': {
      model: {
        prop: 'value',
        event: 'input'
      },
      props: ['value'],
      template: `
        <input 
          :value="value"
          @input="$emit('input', $event.target.value)"
        >
      `
    }
  }
}
</script>

方法 2:使用 Vue 2.6+ 的 v-model 语法糖

vue 如何实现vmodel

<template>
  <custom-input v-model="message"></custom-input>
</template>

<script>
export default {
  data() {
    return {
      message: ''
    }
  },
  components: {
    'custom-input': {
      props: ['modelValue'],
      emits: ['update:modelValue'],
      template: `
        <input 
          :value="modelValue"
          @input="$emit('update:modelValue', $event.target.value)"
        >
      `
    }
  }
}
</script>

在 Vue 3 中使用 v-model

Vue 3 对 v-model 进行了改进,支持多个 v-model 绑定。

<template>
  <custom-input v-model="message"></custom-input>
</template>

<script>
import { defineComponent } from 'vue'

export default defineComponent({
  data() {
    return {
      message: ''
    }
  },
  components: {
    'custom-input': {
      props: ['modelValue'],
      emits: ['update:modelValue'],
      template: `
        <input 
          :value="modelValue"
          @input="$emit('update:modelValue', $event.target.value)"
        >
      `
    }
  }
})
</script>

实现多个 v-model 绑定(Vue 3)

在 Vue 3 中,可以为自定义组件绑定多个 v-model

<template>
  <user-form 
    v-model:name="name" 
    v-model:email="email"
  ></user-form>
</template>

<script>
import { defineComponent } from 'vue'

export default defineComponent({
  data() {
    return {
      name: '',
      email: ''
    }
  },
  components: {
    'user-form': {
      props: ['name', 'email'],
      emits: ['update:name', 'update:email'],
      template: `
        <div>
          <input 
            :value="name"
            @input="$emit('update:name', $event.target.value)"
          >
          <input 
            :value="email"
            @input="$emit('update:email', $event.target.value)"
          >
        </div>
      `
    }
  }
})
</script>

通过以上方法,可以灵活地在 Vue 中实现 v-model 的双向数据绑定功能。

标签: 如何实现vue
分享给朋友:

相关文章

vue公共列表的实现

vue公共列表的实现

实现 Vue 公共列表组件 公共列表组件通常用于展示重复结构的数据,例如商品列表、用户列表等。以下是一个典型的实现方式: 基础实现 创建可复用的列表组件 List.vue: <tem…

vue 指令实现

vue 指令实现

Vue 指令实现 Vue 指令是 Vue.js 提供的特殊属性,用于在 DOM 元素上添加特殊行为。指令以 v- 前缀开头,例如 v-model、v-if、v-for 等。以下是实现自定义指令和常用内…

vue实现cs

vue实现cs

Vue 实现 CS(Client-Side)渲染的常见方法 Vue.js 是一个用于构建用户界面的渐进式框架,默认采用客户端渲染(CSR)。以下是几种常见的实现方式: 使用 Vue CLI 创建项目…

javascript实现vue

javascript实现vue

Vue.js 的基本实现 在 JavaScript 中实现 Vue.js 的核心功能,主要包括数据绑定、响应式系统和虚拟 DOM。以下是一个简化的实现示例。 数据响应式系统 通过 Object.de…

vue实现portal

vue实现portal

Vue 实现 Portal 功能 Portal 是一种将子节点渲染到父组件 DOM 层级之外的 DOM 节点的技术,常用于实现模态框、弹出层等需要脱离当前组件层级的场景。Vue 可以通过多种方式实现…

vue 实现后退

vue 实现后退

实现后退功能的方法 在Vue中实现后退功能通常需要结合浏览器历史记录API或Vue Router的导航方法。以下是几种常见的实现方式: 使用Vue Router的go方法 this.$router…