Vue3 表单

本文详细介绍了Vue3中v-model在不同表单元素如input、textarea、checkbox、radio和select上的应用,包括如何实现双向数据绑定,以及.v-model.lazy、.number、.trim等修饰符的使用。

 Vue 表单上的应用。

我们可以用 v-model 指令在表单 <input><textarea> 及 <select> 等元素上创建双向数据绑定。

v-model 会根据控件类型自动选取正确的方法来更新元素。

v-model 会忽略所有表单元素的 value、checked、selected 属性的初始值,使用的是 data 选项中声明初始值。

v-model 在内部为不同的输入元素使用不同的属性并抛出不同的事件:

  • text 和 textarea 元素使用 value 属性和 input 事件;
  • checkbox 和 radio 使用 checked 属性和 change 事件;
  • select 字段将 value 作为属性并将 change 作为事件。

输入框

实例中演示了 input 和 textarea 元素中使用 v-model 实现双向数据绑定:

<div id="app"> <p>input 元素:</p> <input v-model="message" placeholder="编辑我……"> <p>input 表单消息是: {{ message }}</p> <p>textarea 元素:</p> <textarea v-model="message2" placeholder="多行文本输入……"></textarea> <p>textarea 表单消息是:</p> <p style="white-space: pre">{{ message2 }}</p> </div> <script> const app = { data() { return { message: '', message2: '菜鸟教程\r\nhttps://www.runoob.com' } } } Vue.createApp(app).mount('#app') </script>


在文本区域 textarea 插值是不起作用,需要使用 v-model 来代替:

<!-- 错误 -->
<textarea>{{ text }}</textarea>

<!-- 正确 -->
<textarea v-model="text"></textarea>

复选框

复选框如果是一个为逻辑值,如果是多个则绑定到同一个数组:

复选框

以下实例中演示了复选框的双向数据绑定:

<div id="app"> <p>单个复选框:</p> <input type="checkbox" id="checkbox" v-model="checked"> <label for="checkbox">{{ checked }}</label> <p>多个复选框:</p> <input type="checkbox" id="runoob" value="Runoob" v-model="checkedNames"> <label for="runoob">Runoob</label> <input type="checkbox" id="google" value="Google" v-model="checkedNames"> <label for="google">Google</label> <input type="checkbox" id="taobao" value="Taobao" v-model="checkedNames"> <label for="taobao">taobao</label> <br> <span>选择的值为: {{ checkedNames }}</span> </div> <script> const app = { data() { return { checked : false, checkedNames: [] } } } Vue.createApp(app).mount('#app') </script>

实例中勾选复选框效果如下所示:

单选按钮

以下实例中演示了单选按钮的双向数据绑定:

单选按钮

<div id="app"> <input type="radio" id="runoob" value="Runoob" v-model="picked"> <label for="runoob">Runoob</label> <br> <input type="radio" id="google" value="Google" v-model="picked"> <label for="google">Google</label> <br> <span>选中值为: {{ picked }}</span> </div> <script> const app = { data() { return { picked : 'Runoob' } } } Vue.createApp(app).mount('#app') </script>

选中后,效果如下图所示:

select 列表

以下实例中演示了下拉列表的双向数据绑定:

select

<div id="app"> <select v-model="selected" name="site"> <option value="">选择一个网站</option> <option value="www.runoob.com">Runoob</option> <option value="www.google.com">Google</option> </select> <div id="output"> 选择的网站是: {{selected}} </div> </div> <script> const app = { data() { return { selected: '' } } } Vue.createApp(app).mount('#app') </script>

选取 Runoob,输出效果如下所示:

多选时会绑定到一个数组:

select

<div id="app"> <select v-model="selected" name="fruit" multiple> <option value="www.runoob.com">Runoob</option> <option value="www.google.com">Google</option> <option value="www.taobao.com">Taobao</option> </select> <div id="output"> 选择的网站是: {{selected}} </div> </div> <script> const app = { data() { return { selected: '' } } } Vue.createApp(app).mount('#app') </script>

选中 Runoob 和 Google:

使用 v-for 循环输出选项:

select

<div id="app" class="demo"> <select v-model="selected"> <option v-for="option in options" :value="option.value"> {{ option.text }} </option> </select> <span>选择的是: {{ selected }}</span> </div> <script> const app = { data() { return { selected: 'www.runoob.com', options: [ { text: 'Runoob', value: 'www.runoob.com' }, { text: 'Google', value: 'www.google.com' }, { text: 'Taobao', value: 'www.taobao.com' } ] } } } Vue.createApp(app).mount('#app') </script>

选中 Runoob:

值绑定

对于单选按钮,复选框及选择框的选项,v-model 绑定的值通常是静态字符串 (对于复选框也可以是布尔值):

<!-- 当选中时,`picked` 为字符串 "a" -->
<input type="radio" v-model="picked" value="a" />

<!-- `toggle` 为 true 或 false -->
<input type="checkbox" v-model="toggle" />

<!-- 当选中第一个选项时,`selected` 为字符串 "abc" -->
<select v-model="selected">
  <option value="abc">ABC</option>
</select>

但是有时我们可能想把值绑定到当前活动实例的一个动态属性上,这时可以用 v-bind 实现,此外,使用 v-bind 可以将输入值绑定到非字符串。

复选框 (Checkbox):

<input type="checkbox" v-model="toggle" true-value="yes" false-value="no" />
...
// 选中时
vm.toggle === 'yes'
// 取消选中 
vm.toggle === 'no'

单选框 (Radio):

<input type="radio" v-model="pick" v-bind:value="a" />
// 当选中时
vm.pick === vm.a

选择框选项 (Select):

<select v-model="selected">
  <!-- 内联对象字面量 -->
  <option :value="{ number: 123 }">123</option>
</select>
// 当被选中时
typeof vm.selected // => 'object'
vm.selected.number // => 123

修饰符

.lazy

在默认情况下, v-model 在 input 事件中同步输入框的值与数据,但你可以添加一个修饰符 lazy ,从而转变为在 change 事件中同步:

<!-- 在 "change" 而不是 "input" 事件中更新 -->
<input v-model.lazy="msg" >

.number

如果想自动将用户的输入值转为 Number 类型(如果原值的转换结果为 NaN 则返回原值),可以添加一个修饰符 number 给 v-model 来处理输入值:

<input v-model.number="age" type="number">

这通常很有用,因为在 type="number" 时 HTML 中输入的值也总是会返回字符串类型。

.trim

如果要自动过滤用户输入的首尾空格,可以添加 trim 修饰符到 v-model 上过滤输入:

<input v-model.trim="msg">
### Vue3 中实现表单渲染与显示 在 Vue 3 的生态系统中,有多种方式可以实现表单的渲染与显示。以下是几种常见的方法及其特点: #### 使用 `vue-form-render` 实现基于 JSON Schema 的表单渲染 `vue-form-render` 是一个专注于 Vue 3.x 的表单渲染库,它允许开发者通过定义 JSON Schema 来快速生成自定义配置接口[^1]。这种方式非常适合需要动态生成复杂表单的应用场景。 - **JSON Schema 定义** 开发者可以通过编写 JSON Schema 描述表单结构,包括字段名称、类型、默认值以及校验规则等。 - **模板集成** ```html <template> <form-render :schema="formSchema" /> </template> <script setup lang="ts"> import { ref } from &#39;vue&#39;; import FormRender from &#39;vue-form-render&#39;; const formSchema = ref({ type: &#39;object&#39;, properties: { name: { type: &#39;string&#39;, title: &#39;姓名&#39; }, age: { type: &#39;number&#39;, title: &#39;年龄&#39; } } }); </script> ``` 这种方案的优点在于开发效率高,尤其适合需要频繁调整表单逻辑的情况。 --- #### 动态构建表单并实现数据绑定与验证 对于更加灵活的需求,可以直接利用 Vue 3 提供的功能来手动创建动态表单[^2]。这通常涉及以下几个方面: - **双向数据绑定 (`v-model`)** Vue 3 支持强大的双向绑定机制,能够轻松同步视图层和模型层的状态变化。 ```html <template> <input v-model="formData.name" placeholder="请输入名字" /> <input v-model.number="formData.age" placeholder="请输入年龄" /> </template> <script setup lang="ts"> import { reactive } from &#39;vue&#39;; const formData = reactive({ name: &#39;&#39;, age: null, }); </script> ``` - **自定义属性绑定 (true-value/false-value)** 对于某些特定类型的输入框(如复选框),可以借助 `true-value` 和 `false-value` 属性进一步增强功能[^3]。 ```html <input type="checkbox" v-model="toggleValue" true-value="yes" false-value="no" /> <script setup lang="ts"> import { ref } from &#39;vue&#39;; const toggleValue = ref(&#39;no&#39;); </script> ``` - **动态增删字段** 可以通过数组操作或者条件渲染的方式动态管理表单项的数量和可见性。 --- #### 子组件重新渲染技术 如果某个子组件负责部分表单展示,并且需要强制更新其状态,则可通过控制 `v-if` 或调用 `nextTick` 方法完成重载[^4]。 ```html <template> <ChildForm v-if="refreshFlag" /> </template> <script setup lang="ts"> import { ref } from &#39;vue&#39;; const refreshFlag = ref(true); function reloadChild() { refreshFlag.value = false; setTimeout(() => { refreshFlag.value = true; }, 500); } </script> ``` 这种方法适用于当父级触发事件后需立即反映最新数据至子组件中的情况。 --- ### 总结 以上分别介绍了三种不同的 Vue 3 表单渲染与显示的技术路径:一是采用第三方库 `vue-form-render` 基于 JSON Schema 自动生成;二是依靠原生 Vue 数据绑定特性手写动态表单;三是针对特殊需求设计可独立刷新的子组件形式。每种方式都有各自适用范围,请根据具体业务背景选择最合适的解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值