如何使用@HostListener 传递 window:scroll 目标来触发 Observable.fromEvent() 订阅?

How to pass window:scroll target using @HostListener to trigger an Observable.fromEvent() subscription?

我想保留 @HostListner 中使用的类似语法,并使用 fromEvent() 从该事件创建流。当前滚动未触发 fromEvent 订阅。

问题: 如何触发 var source = Observable.fromEvent(target, 'window:scroll');

import { Directive, HostListener } from '@angular/core';
import {Observable} from "rxjs";
import 'rxjs/add/observable/fromEvent';

@Directive({
  selector: '[mh-scroll]'
})
export class MhScroll {
  lastKnownScrollPosition: number;
  ticking: boolean;

  constructor() {
    this.lastKnownScrollPosition = 0;
    this.ticking = false;
  }


    isElementCloseToTop(target) {

      var source = Observable.fromEvent(target, 'window:scroll'); //this never triggers.

      var subscription = source.subscribe(
          (x) => {
            console.log('Next: Clicked!');
          },
          (err) => {
            console.log('Error: %s', err);
          },
          () => {
            console.log('Completed');
          });

      this.ticking = false;
    }


    @HostListener('window:scroll', ['$event.target'])
    triggeredScroll(target) {
      this.lastKnownScrollPosition = window.scrollY;

      if (!this.ticking) {
        window.requestAnimationFrame(this.isElementCloseToTop.bind(this, target));
      }

      this.ticking = true;
    }
}

我猜应该是

var source = Observable.fromEvent(window, 'scroll');

我发现这很有用:

Observable.fromEvent(window, 'wheel')