v-model的js原生写法和底层原理

数据绑定

v-model原理

  • 原理:

    html 复制代码
    <template>
      <div id="app">
        <input v-model="msg" type="text">   //在vue中提供数据的双向绑定
        //这里两个输入框作用都是一样的
        //v-bind 的作用是使得 HTML 元素的某个属性能够动态地根据 Vue 实例中的数据进行更新,监听input输入值
        <input :value="msg" @input="msg = $event.target.value" type="text">
      </div>
    </template>

    两者区别

    • v-model: vue实例中数据更新视图更新,视图更新数据就更新
    • :value: 如果只写:value="msg" 这一步,数据变化视图也变化,但视图变化数据就不会更新到data中,此时就对输入框进行事件监听@input,将获取的值赋值给msg, $event事件的形参

表单类组件封装 & v-model 简化

表单类组件封装

​ 在组件拆分当中,当把多个表单进行封装模块化时,把数据放在父组件中,实现表单提交数据,子组件通过父传子拿到数据后,如果直接用v-model数据绑定,是不能直接和props传递的数据进行绑定的,子组件修改修改数据时就不方便,不能使用v-model是因为数据是父组件提供的:value的思路就方便很多

父组件

html 复制代码
  <BaseSelect :cityId="select" @事件名="selectId = $event"></BaseSelect>   //父组件传递数据,监听子组件事件

子组件

html 复制代码
  <select :value="cityId" @change="handelChange"> </select>
javascript 复制代码
  props: {
    cityId: String
  }
javascript 复制代码
  methods: {
    handleChange (e) {
      this.$emit('事件名',e.target.value)
    }
  }

代码逻辑:子组件接收到cityId数据时 ,用:value数据绑定,然后对下拉框事件@change进行监听,方法 handleChange发送修改请求给父组件,父组件监听事件名

父组件v-model简化代码

​ 父组件可以用 v-model,实现父组件和子组件的双向数据绑定,子组件中props通过value接收事件触发 input

父组件中vimodel给组件直接绑定数据

html 复制代码
<BaseSlect :value="selectId" @input="selectId = $event"></BaseSlect> //v-model的原理
//直接写v-model的前提是,子组件中配置好:value  和  @input
<BaseSlect v-model="selectId"></BaseSlect>
html 复制代码
<select :value="value" @change="handleChange">
  
</select>
javascript 复制代码
props: {
  value: String
}
javascript 复制代码
methods: {
  handleChange(e) {
    this.$emit('input',e.target.value)
  }
}

代码逻辑:子组件接收数据的属性名直接改为value,都组件穿过来的数据就是value,向父组件发送修改的事件名为input,子组件代码修改没有太多

.sync修饰符

  • 作用:可以实现子组件和父组件数据的双向绑定
  • props属性名可以自定义,非固定为value,提高可读性
  • 场景:封装弹框类的基础组件, visible属性 true显示,false隐藏
相关推荐
冴羽31 分钟前
Cloudflare 崩溃梗图
前端·javascript·vue.js
前端摸鱼匠2 小时前
Vue 3 的watchEffect函数:介绍watchEffect的基本用法和特点
前端·javascript·vue.js·前端框架·ecmascript
一 乐3 小时前
农产品电商|基于SprinBoot+vue的农产品电商系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot
李剑一5 小时前
我用Trae生成了一个Echarts 3D柱状图的Demo
前端·vue.js·trae
一 乐5 小时前
宠物猫店管理|宠物店管理|基于Java+vue的宠物猫店管理管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·后端·宠物管理
熊猫比分管理员6 小时前
【全栈源码解决方案】Vue+Java四端齐全,一周交付可运行项目!
java·前端·vue.js
o***74176 小时前
【Nginx 】Nginx 部署前端 vue 项目
前端·vue.js·nginx
一 乐6 小时前
考公|考务考试|基于SprinBoot+vue的考公在线考试系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·课程设计
特级业务专家6 小时前
把 16MB 中文字体压到 400KB:我写了一个 Vite 字体子集插件
javascript·vue.js·vite
humor6 小时前
Quill 2.x 从 0 到 1 实战 - 为 AI+Quill 深度结合铺路
前端·vue.js