javascript – 缓冲区/节流元素使用RxJS拖动事件

我想在连续的事件源(拖动元素)上发生某些事情时实现一个场景 – 但是有一些缓冲/限制.我想收到一个通知让我们说

>每400毫秒
>但仅当源中有新项目时(拖动实际发生)

我与下面概述的油门操作器最接近的想法是等待400毫秒的暂停,然后提供序列 – 它不提供连续拖动的值:

Rx.Observable
      .fromEvent(element,"drag")
      .throttle(400);

我想需要一些计时器的来源,但在这种情况下,如何将计时器源和拖动源与上述标准相结合?

解决方法

Rx使用Schedulers的概念(Rx.Scheduler实例是特定的). throttle方法采用可选的第二个参数,即要使用的调度程序.如果您不提供第二个参数,则使用Rx.Scheduler.timeout.此调度程序使用setTimeout来计划将来的事情.

在您的示例中,这意味着无论何时发生拖动事件,油门都会存储事件,并且不会告诉您相关信息.然后它从现在起安排一个动作400ms(通过调度程序,最终意味着通过setTimeout)来通知你事件.如果在此超时到期之前另一个拖动事件到达,则它将取消超时并开始新的超时.这是因为只有当传入的事件暂停至少400毫秒时,节流才会通知您.这意味着如果你拖得很快,那么在你最终减慢拖动之前你不会得到任何事件.

根据您的描述判断,您可能更愿意使用sample而不是油门.如果在该间隔期间发生任何事件,则样本将每n ms给您一个事件,例如

Rx.Observable
    .interval(500)
    .sample(1500)
    .take(5)
    .subscribe(function (x) {
        console.log('x: ' + x);
    });
<script src='https://rawgit.com/Reactive-Extensions/RxJS/v.2.5.3/dist/rx.all.js'></script>

这将产生价值:

"x: 1"
"x: 4"
"x: 7"
"x: 10"
"x: 13"

其中每个值是间歇值总和的平均值,即:

>(0 1 2)/ 3 = 1
>(3 4 5)/ 3 = 4
> ……

你会这样使用它:

Rx.Observable
    .fromEvent(element,'drag')
    .sample(400)
    .subscribe(function (e) {
        // ...
    });

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


kindeditor4.x代码高亮功能默认使用的是prettify插件,prettify是Google提供的一款源代码语法高亮着色器,它提供一种简单的形式来着色HTML页面上的程序代码,实现方式如下: 首先在编辑器里面插入javascript代码: 确定后会在编辑器插入这样的代码: <pre
这一篇我将介绍如何让kindeditor4.x整合SyntaxHighlighter代码高亮,因为SyntaxHighlighter的应用非常广泛,所以将kindeditor默认的prettify替换为SyntaxHighlighter代码高亮插件 上一篇“让kindeditor显示高亮代码”中已经
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高
JS对象如何转为json格式字符串
JS怎么获取图片原始宽高
怎么在click事件中调用多个js函数
js如何往数组中添加新元素
js如何拆分字符串
JS怎么对数组内元素进行求和
JS如何判断屏幕大小
js怎么解析json数据
js如何实时获取浏览器窗口大小
原生JS实现别踩白块小游戏(五)
原生JS实现别踩白块小游戏(一)