如何创建不冒泡的事件的可观察序列?
How to Create an Observable Sequence of an Event that does not Bubble?
处理冒泡的事件包括在最顶层元素上创建事件的可观察对象并过滤流,例如
let view,
formView;
formView = (count, query) =>
<form id='search-form'>
<input type='text' id='query' />
<div>count: {count}, query: {query}</div>
</form>;
view = () => {
let input,
count = 0;
input = Observable
.fromEvent(document, 'keyup')
.filter(e => e.target.id === 'query');
return input
.map((e) => {
return formView(++count, e.target.value);
})
.startWith(formView(0));
}
我不明白如何订阅不冒泡的事件,例如"focus"
input = Observable
// event 'focus' does not bubble to the document
.fromEvent(document, 'focus')
.filter(e => e.target.id === 'query');
我做不到:
input = Observable
.fromEvent(document.querySelector('#query'), 'focus')
[..]
因为在执行代码时,#query
元素不存在。
要回答您评论中关于冒泡焦点的问题,请使用 focusin event instead. It bubbles. Use this polyfill for Firefox。
要回答您的主要问题,您需要在每次生成新的 DOM 元素时调用 fromEvent
。很难显示确切的代码,因为您拥有的代码没有意义 - (当元素获得焦点时,重新创建元素??)。但它可能看起来像:
var focusEvent = view()
.flatMapLatest(v => Rx.Observable.fromEvent(v.children[0], 'focus'));
处理冒泡的事件包括在最顶层元素上创建事件的可观察对象并过滤流,例如
let view,
formView;
formView = (count, query) =>
<form id='search-form'>
<input type='text' id='query' />
<div>count: {count}, query: {query}</div>
</form>;
view = () => {
let input,
count = 0;
input = Observable
.fromEvent(document, 'keyup')
.filter(e => e.target.id === 'query');
return input
.map((e) => {
return formView(++count, e.target.value);
})
.startWith(formView(0));
}
我不明白如何订阅不冒泡的事件,例如"focus"
input = Observable
// event 'focus' does not bubble to the document
.fromEvent(document, 'focus')
.filter(e => e.target.id === 'query');
我做不到:
input = Observable
.fromEvent(document.querySelector('#query'), 'focus')
[..]
因为在执行代码时,#query
元素不存在。
要回答您评论中关于冒泡焦点的问题,请使用 focusin event instead. It bubbles. Use this polyfill for Firefox。
要回答您的主要问题,您需要在每次生成新的 DOM 元素时调用 fromEvent
。很难显示确切的代码,因为您拥有的代码没有意义 - (当元素获得焦点时,重新创建元素??)。但它可能看起来像:
var focusEvent = view()
.flatMapLatest(v => Rx.Observable.fromEvent(v.children[0], 'focus'));