我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue中怎么控制表单输入

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue中怎么控制表单输入

这篇文章主要介绍“Vue中怎么控制表单输入”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue中怎么控制表单输入”文章能帮助大家解决问题。

Vue中v-model的思路很简单。定义一个可响应式的text(通常是一个ref),然后用v-model="text"将这个值绑定到一个input上。这就创造了一个双向的数据流:

用户在输入框中输入,text会发生变化。 text发生变化,输入框的值也随之变化。

绑定表单输入

让我们实现一个组件,渲染一个初始值为Unknown的输入表单。用户在输入表单中引入的值会在屏幕上渲染出来。

v-model很适合实现这样一个组件。将v-model与输入表单连接起来需要两个简单的步骤:

const text = ref():作为v-model可响应式的值。 v-model="text":将v-model添加到分配有text的输入表单标签中。

<script setup>import { ref } from 'vue'const text = ref('Unknown') // Step 1: create data bus</script><template>  <!-- Step 2: assign data bus to v-model -->  <input v-model="text" type="input" />  <div>{{ text }}</div></template>

输入表单包含初始值Unknown。在输入表单里输入一些东西:输入值和屏幕上的文本都会更新。

v-model="text" 在Vue中属于双向绑定数据。

第一个方向的流动发生在初始化过程中。输入值被初始化为Unknown,也就是text的初始值。

第二个方向的流动发生在给输入表单键入值的时候。v-model接受输入框的值,并用它来更新text

Vue中怎么控制表单输入

v-model与v-bind

在Vue中,v-bind是另一种数据绑定机制:

<input v-bind:value="text" type="text" />

可以简写为:

<input :value="text" type="text" />

v-model:value的不同之处是什么?<input :value="value" />是一种单向数据流机制。

为了理解两者的不同之处,让我们将先前的例子从v-model="text"改为:value="text"

<script setup>import { ref } from 'vue'const text = ref('Unknown')</script><template>  <input :value="text" type="input" />  <div>{{ text }}</div></template>

输入表单的初始值为Unknown

在输入表单中键入一些字符,然而&hellip;屏幕上渲染的文本依旧是Unknown

:value="text"让数据流仅仅单向流动:从text流向输入表单。当改变数据表单的值时,并不会改变text

Vue中怎么控制表单输入

总之,v-model实现了双向数据流,而:value实现了单向数据流。

模拟v-model

尽管两者有差异,但是v-model可以使用:value@input进行模拟:

<input v-model="text" type="text" />

也可以表示为:

<input :value="text" @input="text = $event.target.value" type="text" />

下面的代码没有使用v-model,但双向数据流仍然生效:

<script setup>import { ref } from 'vue'const text = ref('Unknown')</script><template>  <input     :value="text"     @input="text = $event.target.value"     type="input"   />  <div>{{ text }}</div></template>

常规绑定:value="text"开启了第一个流程。

当用户在输入表单中输入时会触发@input="text = $event.target.value",从而更新text。这就是第二个流程。

使用reactive()绑定

reactive()是Vue里的响应式API,可以让对象具有响应式。

ref()reactive()的最大不同点就是,ref()可以存储原始值和对象,而reactive()值接受对象。并且reactive()对象可以直接访问,而不需要像ref()那样需要通过.value属性访问。

让我们实现一个具有姓氏和名字的输入表单,并将这些绑定到一个响应式对象的属性上:

<script setup>import { reactive } from 'vue'const person = reactive({ firstName: 'John', lastName: 'Smith' })</script><template>  <input v-model="person.firstName" type="input" />  <input v-model="person.lastName" type="input" />  <div>Full name is {{ person.firstName }} {{ person.lastName }}</div></template>

const person = reactive({ firstName: '', lastName: '' })创建了一个响应式的对象。

v-model="person.firstName"与名字属性绑定,以及v-model="person.lastName"与姓氏属性绑定。

一个响应式对象的属性可以作为v-model的数据总线。可以使用这种方法来绑定许多输入表单。

绑定不同输入类型

许多其他的输入类型比如说selecttextareacheckboxradio都可以使用v-model绑定。让我们来试试吧。

Textarea

textarea绑定一个ref是非常直截了当的。只需要在textarea标签上使用v-model即可:

<script setup>import { ref } from 'vue'const longText = ref("Well... here's my story. One morning...")</script><template>  <textarea v-model="longText" />  <div>{{ longText }}</div></template>

Select

select也就是下拉框,为用户提供了一组预定义的选项供其选择。

绑定下拉框也是非常简单的:

<script setup>import { ref } from 'vue'const employeeId = ref('2')</script><template>  <select v-model="employeeId">    <option value="1">Jane Doe</option>    <option value="2">John Doe</option>    <option value="3">John Smith</option>  </select>  <div>Selected id: {{ employeeId }}</div></template>

employeeId是与select绑定的ref,将获得被选择的选项的值。

因为employeeId被初始化为'2',因此John Doe选项会被选中。

当你选择另一个选项时,你可以看到employeeId以新选择的选项值进行更新。

如果select的选项没有value属性,那么就用选项的文本值进行绑定:

<script setup>import { ref } from 'vue'const employee = ref('Jane Doe')</script><template>  <select v-model="employee">    <option>Jane Doe</option>    <option>John Doe</option>    <option>John Smith</option>  </select>  <div>Selected: {{ employee }}</div></template>

现在,绑定直接与选项的文本值共同生效。如果你选择了第二个选项,那么employee将被分配为"John Doe"

Checkbox

感谢v-model让绑定复选框很容易:

<input ref="checked" type="checkbox" />

checked被赋予一个布尔值,表示该复选框是否被选中。

让我们创建一个复选框,并绑定checked

<script setup>import { ref } from 'vue'const checked = ref(true)</script><template>  <label><input v-model="checked" type="checkbox" />Want a pizza?</label>  <div>{{ checked }}</div></template>

checked的初始值是true,因此复选框默认是被选中的。勾选或不勾选复选框,会相应地将checked更新为truefalse

为了将勾选或不勾选绑定到布尔值以外的其他自定义值,Vue在复选框上提供了2个Vue特有的属性:

<input   v-model="checked"   true-value="Yes!"   false-value="No" />

现在,checked被赋值为'Yes!''No'字符串,这取决于复选框的状态。

让我们使用自定义值'Yes!''No'来修改先前的例子:

<script setup>import { ref } from 'vue'const answer = ref('Yes!')</script><template>  <label>    <input v-model="answer" type="checkbox" true-value="Yes!" false-value="No"  />    Want a pizza?  </label>  <div>{{ answer }}</div></template>

现在,answer'Yes!''No'取决于复选框的选中状态。

Radio

要绑定一组单选按钮,要对该单选组应用相同的总线绑定v-model="option"

<input type="radio" v-model="option" value="a" /><input type="radio" v-model="option" value="b" /><input type="radio" v-model="option" value="c" />

举个例子,让我们实现一组单选按钮,来选择T恤的颜色:

<script setup>import { ref } from "vue"const color = ref("white")</script><template>  <label><input type="radio" v-model="color" value="white" />White</label>  <label><input type="radio" v-model="color" value="red" />Red</label>  <label><input type="radio" v-model="color" value="blue" />Blue</label>  <div>T-shirt color: {{ color }}</div></template>

初始情况下,White单选框会被选中,因为color的初始值为'white'

点击其他任意T恤颜色,并根据选定的颜色改变color

单选框的value属性是可绑定的:你可以使用:value。当选项列表来自一个数组时这很有帮助:

<script setup>import { ref } from "vue"const color = ref("white")const COLORS = [  { option: "white", label: "White" },  { option: "black", label: "Black" },  { option: "blue", label: "Blue" },]</script><template>  <label v-for="{ option, label } in COLORS" :key="option">    <input type="radio" v-model="color" :value="option" /> {{ label }}  </label>  <div>T-shirt color: {{ color }}</div></template>

v-model修饰符

除了在绑定表单输入方面做得很好之外,v-model还有一个额外的功能,叫做修饰符。

修饰符是应用于v-model的一段逻辑,用于自定义其行为。修饰符通过使用点语法v-model.<modifier>应用于v-model,例如v-mode.trim

默认情况下,Vue提供了3个修饰符,trimnumberlazy

trim

清除一个字符串是指删除字符串开头和结尾的空白处。例如,清除应用于' Wow! '的结果是'Wow!'

v-model.trim修饰符在赋值给绑定的ref之前清除输入表单的值:

<script setup>import { ref } from 'vue'const text = ref('')</script><template>  <input v-model.trim="text" type="text" />  <pre>"{{ text }}"</pre></template>

number

v-model.number修饰符在输入表单的值上应用一个数字解析器。

如果用户引入了一个可以解析为数字的值,v-model.number="number"则将解析后的数字分配给number。在其他情况下,如果引入的值不是数字,number就会被分配为原始字符串。

<script setup>import { ref } from "vue";const number = ref("");</script><template>  <input v-model.number="number" type="text" />  <div>{{ typeof number }}</div></template>

当你在input中引入'345',那么number就会变成345(一个数字)。值解析会自动发生。

但是如果你在input中引入一个非数值,比如'abc',那么number就会被分配为相同的值'abc'

lazy

默认情况下,当绑定的值更新时,v-model会使用input事件。但如果使用修饰符v-model.lazy,你可以将该事件改为change事件。

inputchange事件的主要区别是什么呢?

input是每当你在输入表单键入时就会触发。 change是只有当你把焦点从输入表单移开时,才会触发。在输入表单里输入并不会触发change事件。

下面示例使用了lazy绑定:

<script setup>import { ref } from 'vue'const text = ref('Unknown')</script><template>  <input v-model.lazy="text" type="input" />  <div>{{ text }}</div></template>

如果你有一个许多输入字段和大量状态的表单,你可以应用lazy修饰符来禁用用户输入时的实时响应。这可以防止输入时页面卡住。

关于“Vue中怎么控制表单输入”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue中怎么控制表单输入

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue中怎么控制表单输入

这篇文章主要介绍“Vue中怎么控制表单输入”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue中怎么控制表单输入”文章能帮助大家解决问题。Vue中v-model的思路很简单。定义一个可响应式的tex
2023-07-05

在 Vue 中控制表单输入方法详解

这篇文章主要介绍了在 Vue 中控制表单输入方法详解的相关资料,需要的朋友可以参考下
2023-05-14

vue怎么使用directive限制表单输入整数、小数

这篇文章主要介绍“vue怎么使用directive限制表单输入整数、小数”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue怎么使用directive限制表单输入整数、小数”文章能帮助大家解决问题。
2023-07-05

c#怎么从控制台输入

c# 提供了 5 种从控制台中输入数据的方法:1) console.readline() 读取文本行;2) console.readkey() 读取单个字符,包括特殊字符;3) console.read() 读取单个字符的 unicode
c#怎么从控制台输入
2024-05-12

java怎么读取控制台输入

在Java中,可以使用`Scanner`类来读取控制台输入。以下是一个示例代码:```javaimport java.util.Scanner;public class ConsoleInput {public static void ma
2023-10-12

pycharm控制台怎么输入命令

在 pycharm 中输入控制台命令的步骤:打开控制台("view" > "tool windows" > "terminal");激活控制台(单击控制台窗口);在提示符 (>>>) 下输入命令;按 enter 键执行命令。在 PyChar
pycharm控制台怎么输入命令
2024-04-18

C#控制输入法怎么实现

本篇内容主要讲解“C#控制输入法怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#控制输入法怎么实现”吧!在Windows系统一般都安装了至少三种输入法,在输入数据时常常会切换输入法,虽
2023-06-17

vue使用directive限制表单输入整数、小数的方法

这篇文章主要介绍了vue使用directive限制表单输入整数,小数,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-14

java怎么在控制台输入信息

在Java中,可以使用`Scanner`类来从控制台输入信息。以下是一个简单的示例:```javaimport java.util.Scanner;public class ConsoleInput {public static void
2023-10-12

c#怎么从控制台输入数组

从 c# 控制台输入数组有两种主要方法:使用 array.createinstance()创建一个数组,并逐一读取数组元素。使用 console.readline() 和 split()将字符串表示形式的数组分割并转换为整数。如何从 C#
c#怎么从控制台输入数组
2024-05-14

MyBatis中怎么控制SQL日志输出

在 MyBatis 中,可以通过配置文件来控制 SQL 日志的输出。具体步骤如下:在 MyBatis 的配置文件中,可以使用 标签来配置相关的参数。例如,可以设置 logImpl 参数来指定日志输出的实现类。常用的参数
MyBatis中怎么控制SQL日志输出
2024-04-08

怎么使用scan方法实现控制台输入

这篇文章主要介绍了怎么使用scan方法实现控制台输入的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用scan方法实现控制台输入文章都会有所收获,下面我们一起来看看吧。基本语法scan方法的基本语法如下:f
2023-07-06

怎么将从Java控制台输入的数组进行逆序输出

怎么将从Java控制台输入的数组进行逆序输出?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。实现在控制台输入一个数组,并让其逆序输出源码:import java.util.S
2023-05-31

C#怎么限制TextBox控件内输入值的范围

要限制TextBox控件内输入值的范围,可以使用以下两种方法:1. 使用事件处理程序:在TextBox的KeyPress事件中添加以下代码:```csharpprivate void textBox1_KeyPress(object sen
2023-08-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录