数据双向绑定主要会用Object.defineProperty()
,关于它的用法可查看:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/defineProperty。
可以直接点击查看例子。
代码实现如下:
<!DOCTYPE html>
<html lang="zh-CN">
<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>js数据双向绑定</title>
</head>
<body>
<input id="testInput">
<p id="showTest"></p>
<input id="testInput2">
<p id="showTest2"></p>
<script>
var testInput = document.querySelector('#testInput'),
showTest = document.querySelector('#showTest'),
testInput2 = document.querySelector('#testInput2'),
showTest2 = document.querySelector('#showTest2');
function watch(obj, key, callback){
var oldValue = obj[key];
Object.defineProperty(obj, key, {
get: function(){
return oldValue;
},
set: function(value){
oldValue = value;
callback(value);
}
});
}
function init(obj){
testInput.value = obj.text;
showTest.innerHTML = obj.text;
testInput2.value = obj.message;
showTest2.innerHTML = obj.message;
}
var obj = {
text: 123,
message: 'qwesd'
};
init(obj);
watch(obj, "text", function (val) {
testInput.value = val;
showTest.innerHTML = val;
});
watch(obj, "message", function (val) {
testInput2.value = val;
showTest2.innerHTML = val;
});
testInput.oninput = function (e) {
obj.text = e.target.value;
};
testInput2.oninput = function (e) {
obj.message = e.target.value;
};
</script>
</body>
</html>