原生js双向数据绑定 前端数据劫持Object.defineProperty

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<input type="text" id="dadasdasda">
    //obj.hello为变量
<div id="bbbbb">{{ obj.hello }}</div>

<script type="text/javascript">

var obj={};

//前端数据劫持 对象属性的监听
Object.defineProperty(obj,'hello',{
set:function(val){
console.log("val: ");
console.log(val);
document.getElementById("bbbbb").innerHTML=val;

}
})

document.getElementById("dadasdasda").onkeyup=function (e) {
console.log(e.target.value);

obj.hello=e.target.value;
console.log("obj.hello: "+obj.hello);
}
obj.hello = "";
</script>
</body>
</html>
posted @   haveProgress  阅读(262)  评论(0)    收藏  举报
编辑推荐:
· C#高性能开发之类型系统:从 C# 7.0 到 C# 14 的类型系统演进全景
· 从零实现富文本编辑器#3-基于Delta的线性数据结构模型
· 记一次 .NET某旅行社酒店管理系统 卡死分析
· 长文讲解 MCP 和案例实战
· Hangfire Redis 实现秒级定时任务,使用 CQRS 实现动态执行代码
阅读排行:
· 使用TypeScript开发微信小程序(云开发)-入门篇
· 没几个人需要了解的JDK知识,我却花了3天时间研究
· C#高性能开发之类型系统:从 C# 7.0 到 C# 14 的类型系统演进全景
· 管理100个小程序-很难吗
· 在SqlSugar的开发框架中增加对低代码EAV模型(实体-属性-值)的WebAPI实现支持
点击右上角即可分享
微信分享提示