返回顶部
首页 > 资讯 > 精选 >怎么深入了解vue中的v-model
  • 482
分享到

怎么深入了解vue中的v-model

2023-06-26 04:06:52 482人浏览 泡泡鱼
摘要

这篇文章给大家介绍怎么深入了解Vue中的v-model,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。首先,要明白我们学习v-model的作用是什么一个组件上的 v-model 默认会利用名为 value 的 prop

这篇文章给大家介绍怎么深入了解Vue中的v-model,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

首先,要明白我们学习v-model的作用是什么

一个组件上的 v-model 默认会利用名为 value 的 prop 和名为 input 的事件,但是像单选框、复选框等类型的输入控件可能会将 value attribute 用于不同的目的。model 选项可以用来避免这样的冲突  ---这是在vue官网找到的解答。

其次,是我们要知道v-model的本质以及他的实现原理是什么

在我看来v-model本身就是一个语法糖,实际上就是给我们提供了一个vue的内置指令,通过这样的方式既简化了我们的代码也能让我们明白这个命令应该怎么去使用

使用v-model指令能够让我们直接获取到我们在input框里面输入的内容,将输入的内容保存到我们的data数据里面,当input的value值发生改变的时候就会自动更新data数据同时也会使相应的视图进行更新渲染。

  <div class="about">    <p>{{model}}</p>    <!-- v-model -->    <input type="text" v-model="model">   </div></template><script>export default {  data() {    return {      model:'',    }  },}</script>

双向绑定MVVM他的原理其实就是监听数据当数据发生改变的时候继而更新页面视图。

MVVM流程图

下图就是双向绑定的原理,通过数据劫持以及模板解析通过一步步流程来监听我们的数据更新视图

怎么深入了解vue中的v-model

Observer数据劫持相关代码

Observer其实就是个观察者 他通过循环遍历来监听我们data数据中的每一项,当data数据发生改变的时候,就会通过notify方法派发更新给订阅者,同时进行Compile进行我们的文本编译从而实现部分视图进行更新。

class Observe {    constructor(vm) {        this.walk(vm.data)    }    // 循环遍历 让 data 里每一个key 都监听     walk(data) {        Object.keys(data).forEach( key => {            this.defineReactive(data, key, data[key])        })    }    // 定义响应式  这个函数也是响应式的核心函数    defineReactive(data, key, value) {        let dep = new Dep()        Object.defineProperty(data, key, {            get() {                console.log('触发 get 收集依赖');                // 收集依赖                if( Dep.target ) {                    // 添加订阅者                    dep.addSub(Dep.target)                }                return value            },            set(newValue) {                console.log(value, '触发 set 派发更新');                // 新值覆盖旧值                value = newValue                // 派发更新                dep.notify()            },        })    }}

Watcher视图更新

Watcher就是我们的订阅者,通过update方法进行视图的更新

    constructor(vm, exp, cb ) {        this.vm = vm;        this.exp = exp;        this.cb = cb;        this.value = this.get()    }    // 更新    update() {        this.run()    }    // 更新 DOM    run() {        const value = this.get()        // 新旧值进行比对        if( value !== this.value ) {            // 调用回调函数             this.cb.call(this.vm, value)        }    }    // 收集依赖    get() {        Dep.target = this        let value = this.vm.data[this.exp]        Dep.target = null;        return value    }}

关于怎么深入了解vue中的v-model就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: 怎么深入了解vue中的v-model

本文链接: https://lsjlt.com/news/306927.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么深入了解vue中的v-model
    这篇文章给大家介绍怎么深入了解vue中的v-model,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。首先,要明白我们学习v-model的作用是什么一个组件上的 v-model 默认会利用名为 value 的 prop ...
    99+
    2023-06-26
  • vue中v-model都绑定了什么
    这篇文章主要为大家展示了“vue中v-model都绑定了什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue中v-model都绑定了什么”这篇文章吧。v-m...
    99+
    2024-04-02
  • 怎么深入了解vue2中的 v-model以及让组件支持该语法
    怎么深入了解vue2中的 v-model以及让组件支持该语法,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、v-model 的本质是语法糖。『v-model 本质上不过是...
    99+
    2023-06-22
  • vue中v-model怎么使用
    这篇文章主要讲解了“vue中v-model怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue中v-model怎么使用”吧!在vue中,“v-model”用于将表单输入绑定到对应的模...
    99+
    2023-06-29
  • vue v-model怎么使用
    本文小编为大家详细介绍“vue v-model怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue v-model怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。v-model...
    99+
    2023-06-30
  • vue3组件中v-model的使用以及深入讲解
    目录v-model input中使用双向绑定数据 组件中的v-model 其他写法 总结v-model input中使用双向绑定数据 v-model在vue中我们经常用它与inpu...
    99+
    2024-04-02
  • Vue中v-model,v-bind,v-on的区别是什么
    本篇内容介绍了“Vue中v-model,v-bind,v-on的区别是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!v-modelv-m...
    99+
    2023-07-04
  • vue v-model的详细讲解(推荐!)
    目录v-model的基本使用v-model的原理v-model绑定textareav-model绑定checkboxv-model绑定radiov-model绑定select...
    99+
    2024-04-02
  • Vue中v-model指令有什么用
    小编给大家分享一下Vue中v-model指令有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!v-model这个指令用于在表...
    99+
    2024-04-02
  • vue的v-model是什么及怎么使用
    这篇文章主要介绍了vue的v-model是什么及怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue的v-model是什么及怎么使用文章都会有所收获,下面我们一起来看看吧。v-model是什么v-mod...
    99+
    2023-07-04
  • vue中v-model的实现原理是什么
    这篇文章主要介绍vue中v-model的实现原理是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!v-model的实现原理是什么?为什么要使用VueVue是一款友好的、多用途且高性...
    99+
    2024-04-02
  • 如何分析vue中v-bind和v-model的区别
    如何分析vue中v-bind和v-model的区别,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。区别:1、“v-bind”是单向绑定,而“...
    99+
    2024-04-02
  • vue中v-model双向绑定input输入框问题
    目录vue v-model双向绑定input输入框vue v-model双向绑定原理kalrry表单实现双向绑定组件上的双向绑定总结vue v-model双向绑定input输入框 ...
    99+
    2023-05-17
    vue v-model v-model双向绑定 v-model input输入框
  • Vue中v-bind原理深入探究
    目录前置内容解析模板总结前面我们分析了v-model的原理,接下来我们看看v-bind的实现又是怎样的呢? 前置内容 <template> <div> ...
    99+
    2022-11-13
    Vue v-bind Vue v-bind原理 Vue v-bind作用
  • Vue中v-model指令的原理分析
    小编给大家分享一下Vue中v-model指令的原理分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!vue的v-model是一个...
    99+
    2024-04-02
  • Vue深入理解之v-for中key的真正作用
    目录前言第一种: key 采用 index第二种:key 采用唯一 ID总结前言 大家应该都知道, v-for 中 key 最常用的绑定方式有两种: 第一种用 index第二种用 唯...
    99+
    2024-04-02
  • vue 中怎么利用v-model绑定表单控件
    这篇文章将为大家详细讲解有关vue 中怎么利用v-model绑定表单控件,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、v-model 双向绑定文本<...
    99+
    2024-04-02
  • Vue的v-model指令修饰符怎么使用
    今天小编给大家分享一下Vue的v-model指令修饰符怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1 .lazyv...
    99+
    2023-07-04
  • vue3中v-model的用法详解
    目录绑定单个属性基础绑定computed 绑定🚀 v-model 绑定多个属性🚩 绑定对象修饰符总结绑定单个属性 基础绑定 以 自定义组件 CustomInput...
    99+
    2023-05-17
    Vue3的v-model Vue v-model
  • 深入了解Vue中的动态组件
    1、什么是动态组件动态组件指的是动态切换组件的显示与隐藏。(学习视频分享:vue视频教程)2、如何实现动态组件渲染vue 提供了一个内置的 <component> 组件,专门用来实现动态组件的渲染。示例代码如下:3、使用 kee...
    99+
    2022-11-22
    Vue
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作