07_表单输入绑定

v-model 指令在表单 <input>、<textarea>及 <select>元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。尽管有些神奇,但 v-mode 本质上不过是语法糖。它负责监听用户的输入事件来更新数据,并在某种极端场景下进行一些特殊处理。

说白了这个model用于监听用户输入v-model 就像是连接用户输入和程序数据的一座桥,让两边的数据可以互相同步,这样你就不需要写很多额外的代码来处理这些同步了

html 复制代码
<template>
  <div id="hello">
    <input v-model="msg" placeholder="开始输入吧...">
    <p>{{msg}}</p>
    <button @click="getUserName">获取用户名</button>
  </div>
</template> 

<script>  

export default {
  name: 'HelloComponent',
  data(){
    return{
      msg: ''
    }
  },
  methods: {
   getUserName(){
    console.log(this.msg)
   }
  },
};
</script>

修饰符

.lazy

在默认情况下,v.mode 在每次 input 事件触发后将输入框的值与数据进行同步 。你可以添加 azy 修饰符,从而转为在 change,事件之后进行同步

change事件就是说他不会立刻同步,而是在失去焦点或者回车的时候才会得到同步,因为实现同步的性能其实消耗也是蛮大的

说人话就是:

有时候我们并不需要实时更新,而是希望等到用户完成输入并触发了"change"事件(比如用户输入完内容后,把光标从输入框移开或者按下回车键)之后,再把输入框里的内容更新到后台数据里。这种情况下,就可以通过添加一个"azy"修饰符(可以理解为一种特殊的标记或指令),来改变同步的时机,从实时同步(input 事件后同步)变成在 change 事件后同步。

简单来说,就是通过添加一个标记,改变输入框内容和后台数据同步的时机,从实时同步变成在用户完成输入操作后同步。

普通项目没有必要在输入的同时向服务器请求数据,一般是回车了,失去焦点了才搞!

html 复制代码
<template>
  <div id="hello">
    <input v-model.lazy="msg" placeholder="开始输入吧...">
    <p>{{msg}}</p>
    <!-- <button @click="getUserName">获取用户名</button> -->
  </div>
</template> 

<script>  

export default {
  name: 'HelloComponent',
  data(){
    return{
      msg: ''
    }
  },
  methods: {
  //  getUserName(){
  //   console.log(this.msg)
  //  }
  },
};
</script>

.trim

如果要自动过滤用户输入的首尾空白字符,可以给model添加trim修饰符

说人话就是->用户输入了无关精要的空格我直接帮你处理了

相关推荐
鱼跃鹰飞1 天前
设计模式系列:工厂模式
java·设计模式·系统架构
我是伪码农1 天前
Vue 1.23
前端·javascript·vue.js
a努力。1 天前
国家电网Java面试被问:混沌工程在分布式系统中的应用
java·开发语言·数据库·git·mysql·面试·职场和发展
Yvonne爱编码1 天前
Java 四大内部类全解析:从设计本质到实战应用
java·开发语言·python
wqwqweee1 天前
Flutter for OpenHarmony 看书管理记录App实战:搜索功能实现
开发语言·javascript·python·flutter·harmonyos
J2虾虾1 天前
SpringBoot和mybatis Plus不兼容报错的问题
java·spring boot·mybatis
毕设源码-郭学长1 天前
【开题答辩全过程】以 基于springboot 的豪华婚车租赁系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
HIT_Weston1 天前
107、【Ubuntu】【Hugo】搭建私人博客:模糊搜索 Fuse.js(三)
linux·javascript·ubuntu
Tao____1 天前
通用性物联网平台
java·物联网·mqtt·低代码·开源
曹轲恒1 天前
SpringBoot整合SpringMVC(上)
java·spring boot·spring