1

我正在观察消息并使用消息时间戳跟踪这些观察结果。这些观察有一个重要条件:如果页面上没有客户端活动(光标没有移动,或者他没有输入任何内容),则不应更新跟踪时间戳。客户经常收到一条新消息,但没有任何活动。这意味着一旦完全观察到该元素,Observer 就会跳过该元素。但是当用户实际提供一些活动时,该元素不会被重新观察,这意味着除非比率发生变化,否则永远不会再次调用观察者回调。我如何告诉 IS 重新计算所有观察结果以触发我的回调?

手动“重新观察”元素的问题是,如果元素已经在交集范围内,则永远不会调用回调。

一些伪代码例如:

IS.callback = function(entries, observer){
    for (var entry in entries)
    {
        if (activity && entries.hasOwnProperty(entry))
        {
            if (lastTimestamp < entries[entry].data.timestamp)
                lastTimestamp = entries[entry].data.timestamp;
        }
    }
};
4

1 回答 1

5

解决方案非常简单:移除所有观察者并再次观察元素。然后调用startObserve();任何活动更改。为了简单起见,这里使用 jQuery。

function startObserve()
{
    IS.targets =
        $('#messages .message')
        .each(function(index, target){
            IS.observer.unobserve(target);
            IS.observer.observe(target);
        });
}
于 2017-12-24T16:02:11.120 回答