Я пытался создать простое тестовое приложение, которое принимает пользовательский ввод из текстового поля, отображает его, а также сохраняет его с помощью cycle-idb .Но я продолжаю падать в бесконечные циклы, независимо от того, что я делаю.
Вот вся основная функция:
function intent(domSources) {
return domSources.select('.name')
.events('input')
.map(ev => ev.target.value);
};
function model(input$, db$) {
const log$ = db$;
return xs.combine(input$, log$)
.map(([input, logs]) => {
return {
id: 1,
name: input,
}
}).startWith({id: 1, name: ""});
};
function view(state$) {
return state$.map(log => {
return (
<div>
<label for='name'>Name: </label>
<input
className='name'
type='text'
value={log.name}
placeholder="Enter a log name"
/>
<p>{log.name}</p>
</div>
)
});
};
function persist(state$) {
return state$.map(log => {
return $put('logs', log)
});
};
export function main (sources) {
const db$ = sources.IDB.store('logs').getAll();
const input$ = intent(sources.DOM);
const state$ = model(input$, db$);
const vtree$ = view(state$);
const updateDb$ = persist(state$);
return {
DOM: vtree$,
IDB: updateDb$,
};
}
Я пытаюсь использовать MVI и использовать TodoMVC в качестве примера, но яне могу понять, как управлять циклическими зависимостями без создания этого бесконечного цикла.
Буду очень признателен за любые советы или ссылки на другие ссылки.