首页 > 其他 > 详细

v-model实现原理

时间:2021-02-23 13:38:42      阅读:18      评论:0      收藏:0      [点我收藏+]

vue.js 则是采用数据劫持结合发布者-订阅者模式的方式,

通过Object.defineProperty()来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者,触发相应的监听回调。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <div id="app">
        <input type="text" id="a">
        <span id="b"></span>
    </div>
</body>
<script>
    var obj = {}; //定义一个空对象
    var val = ‘‘; //赋予初始值

    Object.defineProperty(obj, ‘val‘, { //定义要修改对象的属性

        get: function() {
            return val;
        },

        set: function(newVal) {
            val = newVal; //定义val等于修改后的内容
            document.getElementById(‘a‘).value = val; //让文本框的内容等于val
            document.getElementById(‘b‘).innerHTML = val; //让span的内容等于val
        }

    });
    document.addEventListener(‘keyup‘, function(e) { //当在文本框输入内容时让对象里你定义的val等于文本框的值
        obj.val = e.target.value;

    })
</script>

</html>

v-model实现原理

原文:https://www.cnblogs.com/kawayi/p/14435409.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!