這篇文章主要介紹如何使用原生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的數據綁定功能”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。