這篇文章主要介紹“Java中怎么實現實現一個簡單得數據響應系統”,在日常操作中,相信很多人在Java中怎么實現實現一個簡單得數據響應系統問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Java中怎么實現實現一個簡單得數據響應系統”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
其實,這就是一個依賴收集的容器, depend 收集依賴, notify 觸發依賴
class Dep{
constructor() {
this._subs = [];
}
depend () {
this._subs.push(Dep.target)
}
notify() {
this._subs.forEach(item => {
item.fn();
})
}
}
// 其實就是 dep 和 watcher 基情滿滿的開始,watcher 中用到
// 通過一個全局屬性來存 watcher
Dep.target = null;
function pushTarget(watch) {
Dep.target = watch;
}
function popTarget() {
Dep.target = null;
}遞歸,將 data 對象所有屬性轉化為訪問器屬性
// 轉為訪問器屬性
function defineReactive (obj, key, val, shallow) {
// 創建一個依賴收集容器
let dep = new Dep();
let childOb = !shallow && observe(val)
Object.defineProperty(obj, key, {
enumerable: true,
configurable: true,
get: function reactiveGetter () {
if(Dep.target) {
// 收集依賴
dep.depend();
}
return val;
// ...
},
set: function reactiveSetter (newVal) {
if(newVal === val) return;
// 繼續遞歸遍歷
observe(newVal);
// 觸發依賴
dep.notify();
// ...
}
})
}
class Observer{
constructor(data) {
this.walk(data);
}
walk(data) {
const keys = Object.keys(data)
for (let i = 0; i < keys.length; i++) {
defineReactive(data, keys[i], data[keys[i]])
}
}
}
// 遞歸,將 data 對象所有屬性轉化為訪問器屬性
function observe (data) {
if(Object.prototype.toString.call(data) !== '[object Object]') return;
new Observer(data);
}此時就可以把任意一個對象的全部屬性轉為訪問器
const data = {
a: 1,
b: 2
}
// 首先監控一個對象
observe(data);watcher 的主要功能是檢測某個屬性,當屬性變化時觸發一個回調
class Watcher{
/**
* @params {Function} exp 一個屬性表達式
* @params {Function} fn 回調
*/
constructor(exp, fn) {
this.exp = exp;
this.fn = fn;
// 存 watcher
// Dep.target = this;
pushTarget(this);
// 先執行一次表達式函數,會在調用過程中,
// 觸發到 data.a 的訪問器, data.a 的 get 被執行,
// 觸發 dep.depend() 開始收集依賴
this.exp();
// 釋放 Dep.target
popTarget();
}
}
// new Watcher 這樣一個依賴就被收集了
new Watcher(() => {
return data.a + data.b;
}, () => {
console.log('change')
})data.a = 3; // change data.b = 3; // change
到此,關于“Java中怎么實現實現一個簡單得數據響應系統”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。