Comments (6)
pull прийдётся постоянно заворачивать в { pull: /* ... */ }
, неудобно.
Да и в принципе oldValue в pull не нужен вроде в таком случае.
через oldValue можно управлять какое значение будет иметь асинхронная ячейка во время запроса:
var value = cellx((push, fail, oldValue) => {
makeRequest(res => {
push(res.data.value);
});
return oldValue; // на время запроса ячейка останется со старым значением
return oldValue || 0; // на время запроса ячейка останется со старым значением и значение до первого ответа будет `0`.
return null; // на время запроса ячейка будет обнулена.
});
from cellx.
Бывает не надо заворачивать { pull: /* ... */ }
, а надо new CustomCellOptions(bla-bla)
Создание объекта дешевле, чем функции.
from cellx.
Но где-то в bla-bla
тоже ведь функция будет?
from cellx.
Не факт, но надо подумать.
У меня задумка была с очередями, которые управляли бы состоянием атома:
class AsyncQeue<V> {
_defaultValue: V
pull(push, fail, oldValue) {}
push() {} ...
}
const queue = new AsyncQeue('defaut')
cellx(null, queue)
// что не делать (...args) => queue.pull(...args)
from cellx.
Можно писать код так, что генерации функций не будет нигде. Но я про то, что нет единообразия:
pull в ICellOptions, тем более что там уже есть put, reap и т.д.
Почему передача pull вдруг иначе, чем остальные точки расширения?
При попытке интегрироваться с cellx, это порождает вот такие костыли:
class AtomController {
_pull(push: (v: V) => void, fail: (e: Error) => void, oldValue: ?V): V {
//...
}
reap(): void {
this._updater.cancel()
}
pull: PullFn<V> = (
push: (v: V) => void,
fail: (e: Error) => void,
oldValue: ?V
) => this._pull(push, fail, oldValue)
}
const ac = new AtomController()
new cellx.Cell(ac.pull, ac)
from cellx.
Сравни cellxPull и cellxNoPull
Абстракции проще, когда pull/push не в формуле, а отдельно, в виде атомов.
from cellx.
Related Issues (20)
- Guidance requested
- Untranslated part of README HOT 1
- Одно вычисление а не два HOT 2
- Please include Sodium FRP in your PERF
- Как сделать подписку с учётом будущих изменений? HOT 6
- Сломаны removeChangeListener и unsubscribe HOT 4
- dispose throws unexpectedly HOT 1
- why a varargs/overloaded API? HOT 2
- consider switching to Rollup HOT 5
- Good way to implement auto-run? HOT 3
- create-react-app TypeError: undefined has no properties _on EventEmitter.js:102 HOT 14
- Error rethrowed only once HOT 12
- Зачем `let reactions = this._reactions;` HOT 1
- Ожидание корректного значения HOT 1
- Почему dep._addReaction после pull делает ячейку DIRTY? HOT 1
- _deactivate() не чистит this._dependencies HOT 5
- После fail executon всея ячейки дерева state ACTUAL HOT 4
- Async cell HOT 3
- value instanceof EventEmitter. Подписка в конструкторе HOT 1
- "effects" in cellx HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from cellx.