vue的双向绑定原理

细话不多说,直接上代码撸:

<!DOCTYPE html>
<html>
<head>
    <title>Vue数据双向绑定原理实现</title>
</head>
<body>
    <input id="entryData" type="text"></input>
    <div id="showData"></div>
    <script type="text/javascript">
        const obj = {
            pwd: 'dhaskj'
        };

        Object.defineProperty(obj, 'name', {
            get() {
                console.log('get data');
            },
            set(val) {
                console.log('set data');
                document.getElementById('entryData').value = val;
                document.getElementById('showData').innerText = val;
            }
        });

        document.getElementById('entryData').addEventListener('keyup', function(ev) {
            obj.name = ev.target.value;
        });
    </script>
</body>
</html>

通过Object.defineProperty中的get和set方法实现数据的获取以及更改。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容