全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

浅谈vue中数据双向绑定的实现原理

vue中最常见的属v-model这个数据双向绑定了,很好奇它是如何实现的呢?尝试着用原生的JS去实现一下。

首先大致学习了解下Object.defineProperty()这个东东吧!

* Object.defineProperty()
    *  对对象的属性进行 定义/修改
    * */

    let obj = {x:10}
    // 这两种方式都相对来说比较简单,直接,但是有些时候我们需要对对象的属性的修改和增加进行必要的干预
//    obj.y = 20;
//    obj.x = 100;
//    obj.x = 'abc';
//
//    let arr = [1,2,3];
//    arr.length = 'abc';//不可更改
//    console.log(arr);

//    console.log(obj.x);
//    delete obj.x;
//    console.log(obj);

    Object.defineProperty(obj, 'y', {
      configurable: false,  //设置是否可删除 false为不可删除
      value: 100
    });

    console.log(obj);
    delete obj.y;//删除
    console.log(obj);
    //设置对象某个属性值的时候,顺便设置它的属性。enumerable 可枚举 configurable 可以删除否 writable 可改值否
    Object.defineProperty(obj, 'z', {//enumerable 可枚举(没有则新添加) 
      enumerable: true,//为false时,for..in object.keys json.stringfy 不能取到该z属性
      value: 10000
    });

    for (var attr in obj) {
      console.log(attr);
    }

    Object.defineProperty(obj, 'm', {
      writable: false,//可更改
      value: 9
    });

    console.log(obj);
    obj.m = 100;
    console.log(obj);

以上总结了对象的defineProperty四个属性:configurable,enumerable,value,writable

接下来再深入认识下它的另外两个方法:set 以及get

注意:get和set不能与configurable,enumerable,value,writable同时存在

let obj = {x:10}

    let y = 100;
    Object.defineProperty(obj, 'y', {
      get() {
        //当obj的y属性被调用的时候触发,该方法的返回值将作为获取的结果
        console.log('get');
        return y;
      },
      set(value) {
        //当obj的y属性被设置的时候触发
        console.log('set', value);
        y = value;
      }
    })

    console.log(obj.y);
    obj.y = 1;
    console.log(obj.y);

介绍完defineProperty了,最后我们一起看看如何简单的实现数据双向绑定吧!

<body>

  <input type="text" id="age">
  <h1></h1>

  <script>

    var ageElement = document.querySelector('#age');
    var h1Element = document.querySelector('h1');

    let obj = {};

    Object.defineProperty(obj, 'age', {
      get() {

      },
      set(value) {
        ageElement.value = value;
        h1Element.innerHTML = value;
      }
    })

    obj.age = 10;

    ageElement.oninput = function() {
      obj.age = this.value;
    }
    
  </script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# vue实现双向数据绑定  # vue双向绑定实现原理  # vue双向绑定原理  # Vue数据双向绑定原理实例解析  # Vue的双向数据绑定实现原理解析  # 详解Vue双向数据绑定原理解析  # vue双向数据绑定原理探究(附demo)  # 深入了解Vue中双向数据绑定原理  # 它是  # 我们一起  # 定了  # 这两种  # 能与  # 绑定  # 最常见  # 大家多多  # 到该  # 如何实现  # 解下  # 很好奇  # 返回值  # 总结了  # arr  # console  # vue  # length  # configurable  # false 


相关文章: 在线制作视频网站免费,都有哪些好的动漫网站?  如何生成腾讯云建站专用兑换码?  TestNG的testng.xml配置文件怎么写  南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?  如何在企业微信快速生成手机电脑官网?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  如何用西部建站助手快速创建专业网站?  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  如何用PHP快速搭建CMS系统?  微信推文制作网站有哪些,怎么做微信推文,急?  如何零基础在云服务器搭建WordPress站点?  详解jQuery停止动画——stop()方法的使用  如何在阿里云ECS服务器部署织梦CMS网站?  如何用狗爹虚拟主机快速搭建网站?  C#如何使用XPathNavigator高效查询XML  如何选择可靠的免备案建站服务器?  如何设置并定期更换建站之星安全管理员密码?  如何在阿里云虚拟服务器快速搭建网站?  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  微信小程序 五星评分(包括半颗星评分)实例代码  电脑免费海报制作网站推荐,招聘海报哪个网站多?  哈尔滨网站建设策划,哈尔滨电工证查询网站?  海南网站制作公司有哪些,海口网是哪家的?  如何快速登录WAP自助建站平台?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  建设网站制作价格,怎样建立自己的公司网站?  一键网站制作软件,义乌购一件代发流程?  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  如何挑选高效建站主机与优质域名?  头像制作网站在线制作软件,dw网页背景图像怎么设置?  如何快速搭建个人网站并优化SEO?  非常酷的网站设计制作软件,酷培ai教育官方网站?  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  ,制作一个手机app网站要多少钱?  学校免费自助建站系统:智能生成+拖拽设计+多端适配  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  建站主机选购指南与交易推荐:核心配置解析  宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  活动邀请函制作网站有哪些,活动邀请函文案?  网站制作费用多少钱,一个网站的运营,需要哪些费用?  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  建站主机无法访问?如何排查域名与服务器问题  如何在七牛云存储上搭建网站并设置自定义域名? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。