當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript Stream.create方法代碼示例

本文整理匯總了TypeScript中xstream.Stream.create方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Stream.create方法的具體用法?TypeScript Stream.create怎麽用?TypeScript Stream.create使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在xstream.Stream的用法示例。


在下文中一共展示了Stream.create方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: fromEvent

export function fromEvent(
  element: Element | Document,
  eventName: string,
  useCapture = false,
  preventDefault: PreventDefaultOpt = false,
  passive = false,
): Stream<Event> {
  return Stream.create<Event>({
    element: element,
    next: null,
    start: function start(listener: Listener<Event>) {
      if (preventDefault) {
        this.next = function next(event: Event) {
          preventDefaultConditional(event, preventDefault);
          listener.next(event);
        };
      } else {
        this.next = function next(event: Event) {
          listener.next(event);
        };
      }
      this.element.addEventListener(eventName, this.next, {
        capture: useCapture,
        passive,
      });
    },
    stop: function stop() {
      this.element.removeEventListener(eventName, this.next, useCapture);
    },
  } as Producer<Event>);
}
開發者ID:ntilwalli,項目名稱:cyclejs,代碼行數:31,代碼來源:fromEvent.ts

示例2: start

export default function createEventHandler<T>() {
  interface HandlerProducer<T> extends Producer<T> {
    sendValue: (T) => void,
    _listener: Listener<T>
  }
  
  const producer: HandlerProducer<T> = {
    start(listener) {
      this._listener = listener
    },
    stop() {
      this._listener = null
    },
    sendValue(val: T) {
      if (this._listener) {
        this._listener.next(val)
      }
    },
    _listener: null as Listener<T>
  }
  
  const stream = Stream.create(producer)
  
  return {
    stream,
    handler: (val: T) => {
      producer.sendValue(val)
    }
  }
}
開發者ID:JamesHageman,項目名稱:xstream-scrumbler,代碼行數:30,代碼來源:create-event-handler.ts

示例3: fromEvent

export function fromEvent(
  element: Element | Document,
  eventName: string,
  useCapture = false,
  preventDefault: PreventDefaultOpt = false,
  passive = false
): Stream<Event> {
  let next: ((e: Event) => void) | null = null;
  return Stream.create<Event>({
    start: function start(listener: Listener<Event>) {
      if (preventDefault) {
        next = function _next(event: Event) {
          preventDefaultConditional(event, preventDefault);
          listener.next(event);
        };
      } else {
        next = function _next(event: Event) {
          listener.next(event);
        };
      }
      element.addEventListener(eventName, next, {
        capture: useCapture,
        passive,
      });
    },
    stop: function stop() {
      element.removeEventListener(eventName, next as any, useCapture);
      next = null;
    },
  } as Producer<Event>);
}
開發者ID:cyclejs,項目名稱:cyclejs,代碼行數:31,代碼來源:fromEvent.ts

示例4: fromEvent

export function fromEvent(element: Element | Document,
                          eventName: string,
                          useCapture = false): Stream<Event> {
  return Stream.create<Event>({
    element: element,
    next: null,
    start: function start(listener: Listener<Event>) {
      this.next = function next(event: Event) { listener.next(event); };
      this.element.addEventListener(eventName, this.next, useCapture);
    },
    stop: function stop() {
      this.element.removeEventListener(eventName, this.next, useCapture);
    },
  } as Producer<Event>);
}
開發者ID:whitecolor,項目名稱:cyclejs,代碼行數:15,代碼來源:fromEvent.ts

示例5: complete

export const withCompletionMarble$ = (some$: Stream<Marble>, completion_time?: number): Stream<Marble> => {
  const return$ = Stream.create<Marble>();
  let lastTime = 0;
  const getCompletionTime = () => completion_time == undefined ? lastTime : completion_time;
  setTimeout(() =>
    some$.addListener({
      next: marble => {
        lastTime = marble.time;
        if (!marble.complete) return$.shamefullySendNext(marble);
        else complete(return$, getCompletionTime());
      },
      complete: () => complete(return$, getCompletionTime()),
      error: err => return$.shamefullySendError(err)
    }), 30);
  return return$;
};
開發者ID:artfuldev,項目名稱:xstream-marbles,代碼行數:16,代碼來源:helpers.ts

示例6: start

const getMessageStream = (type: string, socket: SocketIOClient.Socket)
  : Stream<IncomingMessage> => {
    
  const producer : Producer<IncomingMessage> = {
    start(listener) {
      socket.on(type, (data) => {
        listener.next({
          type,
          data
        } as IncomingMessage)
      })
    },
    stop() {
      
    }
  }
  return Stream.create(producer)
}
開發者ID:JamesHageman,項目名稱:xstream-scrumbler,代碼行數:18,代碼來源:websocket.ts


注:本文中的xstream.Stream.create方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。