这篇文章主要介绍如何使用原生javascript实现类似vue的数据绑定功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
具体如下:
观察者模式
let observer = {
/*订阅功能*/
addSubscriber: function (cb) {
this.subscribers.push(cb);
},
/*退订功能*/
removerSubscriber: function (cb) {
let index = this.subscribers.indexOf(cb);
this.subscribers.splice(index, 1)
},
// 发布功能
publish: function (what) {
for (let i in this.subscribers) {
if (typeof this.subscribers[i] == "function") {
this.subscribers[i](what);
}
}
},
// 让每个对象具有订阅功能
make:function(obj){
for(let key in this){
obj[key] = this[key];
}
obj.subscribers = [];
},
}
使用实例
// 定义对象
let o = {};
// 实现数据绑定 实现具有发布订阅功能
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 .cls p
if(str.charAt(0)=="#"){
return document.getElementById(str.substring(1));
}else if(str.charAt(0)=="."){
return document.getElementsByClassName(str.substring(1));
}else{
return document.getElementsByTagName(str);
}
}
以上是“如何使用原生javascript实现类似vue的数据绑定功能”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注天达云行业资讯频道!