Comments (4)
- Нет проблем с контекстом когда ячейка используется как свойство:
// prop запуститься в контексте this и он (this) подставиться как контекст обработчика
this.prop('subscribe', function() {});
// subscribe запуститься в контексте prop, а он как контекст обработчику нафик не нужен,
// нужно каждый раз прокидывать контекст вторым параметром,
// это часто случайно забывается
this.prop.subscribe(function() {}, this);
Arrow-функции проблему не решают, так как обработчик почти всегда подставляется из экземпляра:
this.prop('subscribe', this._onPropChange);
Лежать на экземпляре он должен для возможности переопределения в дочерних классах.
- Всякие оптимизационные моменты, ячейка -- это функция, в неё свой прототип не подставишь, приходится переписывать на неё кучу методов, тут, во-первых, замедление от самого переписывания и довольно значительное, во-вторых, сотни-тысячи ячеек в приложении помноженные на десятки методов -- это десятки-сотни тысяч ссылок и как следствие большее потребление памяти, хотя единичная ссылка в js конечно очень легковесна.
Это решение принималось очень давно и там плюсов и минусов было довольно много, я сейчас только основные помню. Плюсы были больше технические, вроде тех, что выше, а минусы в основном из серии "не хочется пугать пользователя чем-то необычным". Ещё серьёзным минусом было то, что появление typescript-а уже тогда было предсказуемым и я считал, что будут проблемы с автодополнением в редакторе, но сегодняшний typescript без проблем позволяет это описать и получить нормальное автодополнение, как-то так вроде:
cellx(methodName: 'subscribe', listener: Function)
cellx(methodName: 'then', onFulfilled: Function, onRejected?: Function)
то есть вместо типа указывается значение и эти значения автодополняются с дальнейшей проверкой компилятором остальной сигнатуры вызова. В общем, этот минус сам собой отпал.
from cellx.
Автодополнения вроде нет в таком случае, есть только подсказка к сигнатуре (всплывающее окно, вместо подстановки). А лично меня смутил нолик, ну и аргументацию было интересно услышать.
А сделать ячейку не функцией, я так понимаю, не позволяет желание сохранить этот синтаксис? Т.е. можно было бы сделать и get, set методы.
var x = cellx();
x.set("new value");
x.get();
from cellx.
Автодополнения вроде нет в таком случае, есть только подсказка к сигнатуре (всплывающее окно, вместо подстановки)
да, точно, тут, наверно, ценнее даже не дополнение, а чтобы компилятор всё это нормально мог проверять.
А сделать ячейку не функцией
в соседнем ишъю как раз немного рассказал про устройство функции cellx:
вызов функции cellx создаёт экземпляр
cellx.Cell
(там сложнее, но для простоты можно и так объяснить) и возвращает функцию которая проксирует часть своих вызовов на его (cellx.Cell
) методы
то есть можно использовать сам класс ячейки:
let x = new cellx.Cell(5);
x.get();
x.subscribe(function() {});
from cellx.
Ага, ну тогда вопрос закрыт, спасибо.
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.