只是尝试一些愚蠢的东西并玩弄 Cycle.js。并遇到问题。基本上我只有一个按钮。当您单击它时,假设将位置导航到随机散列并显示它。几乎就像一个没有预定义路由的愚蠢路由器。IE。路线是动态的。这又不是什么实用的东西,我只是在弄乱一些东西并尝试学习 Cycle.js。但是在我单击“添加”按钮后,下面的代码会崩溃。但是位置已更新。如果我实际上只是导航到“#/asdf”,它会使用“Hash:#/asdf”显示正确的内容。不知道为什么流程因错误而崩溃:
render-dom.js:242 TypeError:无法读取未定义的属性“订阅”(...)
import Rx from 'rx';
import Cycle from '@cycle/core';
import { div, p, button, makeDOMDriver } from '@cycle/dom';
import { createHashHistory } from 'history';
import ranomdstring from 'randomstring';
const history = createHashHistory({ queryKey: false });
function CreateButton({ DOM }) {
const create$ = DOM.select('.create-button').events('click')
.map(() => {
return ranomdstring.generate(10);
}).startWith(null);
const vtree$ = create$.map(rs => rs ?
history.push(`/${rs}`) :
button('.create-button .btn .btn-default', 'Add')
);
return { DOM: vtree$ };
}
function main(sources) {
const hash = location.hash;
const DOM = sources.DOM;
const vtree$ = hash ?
Rx.Observable.of(
div([
p(`Hash: ${hash}`)
])
) :
CreateButton({ DOM }).DOM;
return {
DOM: vtree$
};
}
Cycle.run(main, {
DOM: makeDOMDriver('#main-container')
});
感谢您的帮助