這篇文章主要介紹如何使用原生javascript實現(xiàn)類似vue的數(shù)據(jù)綁定功能,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
為??档鹊貐^(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及??稻W(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為做網(wǎng)站、成都網(wǎng)站建設(shè)、??稻W(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
具體如下:
觀察者模式
let observer = { /*訂閱功能*/ addSubscriber: function (cb) { this.subscribers.push(cb); }, /*退訂功能*/ removerSubscriber: function (cb) { let index = this.subscribers.indexOf(cb); this.subscribers.splice(index, 1) }, // 發(fā)布功能 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 = {}; // 實現(xiàn)數(shù)據(jù)綁定 實現(xiàn)具有發(fā)布訂閱功能 observer.make(o); // 發(fā)布 $("#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實現(xiàn)類似vue的數(shù)據(jù)綁定功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!