原生javascript实现类似vue的数据绑定功能示例【观察者模式】
本文实例讲述了原生javascript实现类似vue的数据绑定功能。分享给大家供大家参考,具体如下:
观察者模式
letobserver={ /*订阅功能*/ addSubscriber:function(cb){ this.subscribers.push(cb); }, /*退订功能*/ removerSubscriber:function(cb){ letindex=this.subscribers.indexOf(cb); this.subscribers.splice(index,1) }, //发布功能 publish:function(what){ for(letiinthis.subscribers){ if(typeofthis.subscribers[i]=="function"){ this.subscribers[i](what); } } }, //让每个对象具有订阅功能 make:function(obj){ for(letkeyinthis){ obj[key]=this[key]; } obj.subscribers=[]; }, }
使用实例
//定义对象 leto={}; //实现数据绑定实现具有发布订阅功能 observer.make(o); //发布 $("#num").oninput=function(){ o.publish(this.value); }; //平方功能 o.addSubscriber(function(num){ $("#sqrnum").value=Math.pow(num,2); }); o.addSubscriber(function(num){ $("#cubenum").value=Math.pow(num,3); }); o.addSubscriber(function(num){ $("#fourFangnum").value=Math.pow(num,4); }); o.addSubscriber(function(num){ $("#sqrtnum").value=Math.sqrt(num); }); } function$(str){//#box.clsp if(str.charAt(0)=="#"){ returndocument.getElementById(str.substring(1)); }elseif(str.charAt(0)=="."){ returndocument.getElementsByClassName(str.substring(1)); }else{ returndocument.getElementsByTagName(str); } }
感兴趣的朋友可以使用在线HTML/CSS/JavaScript前端代码调试运行工具:http://tools.jb51.net/code/WebCodeRun测试上述代码运行效果。
更多关于JavaScript相关内容还可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。