前端面試題整理——VUE雙向綁定原理


VUE2.0和3.0數據雙向綁定的原理,並說出其區別。

代碼:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>vue2.0/3.0雙向數據綁定原理</title>
</head>
<body>
姓名:<span id="name"></span>
<br>
<input type="text" id="inputText" oninput="changeTxt2()">
<hr>
姓名:<span id="name2"></span>
<br>
<input type="text" id="inputText2" oninput="changeTxt2()">

<script>
    // 2.0
    // ES5:Object.defineProperty 數據劫持實現
    let obj = {name: ''};
    let newObj = JSON.parse(JSON.stringify(obj))
    Object.defineProperty(obj, 'name', {
        get() {
            return newObj.name
        },
        set(value) {
            if (value === newObj.name) return;
            newObj.name = value;
            observer();
        }
    })

    function observer() {
        document.getElementById('name').innerHTML = document.getElementById('inputText').value = obj.name;
    }

    function changeTxt() {
        obj.name = document.getElementById('inputText').value;
    }

    /*
    * 弊端:
    * 1、需要將原來的對象克隆一份
    * 2、需要分別給對象中指定每一個屬性設置監聽
    * */

    // 3.0
    // ES6:Proxy 委托代理
    let obj2 = {};
    obj2 = new Proxy(obj2, {
        get(target, prop) {
            // target,代理的對象
            // prop,代理對象的屬性
            return target[prop]
        },
        set(target, prop, value) {
            target[prop] = value
            observer2()
        }
    })
    // 不需要克隆,只需要整個對象進行代理
    function observer2() {
        document.getElementById('name2').innerHTML = document.getElementById('inputText2').value = obj2.name;
    }
    function changeTxt2() {
        obj2.name = document.getElementById('inputText2').value;
    }
</script>
</body>
</html>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM