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


TypeScript DOM.createCustomEvent方法代碼示例

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


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

示例1: exerciseBehavior

    function exerciseBehavior(callback) {
      let sourceCalls = 0;
      let source = {
        handleClick: e => {
          // console.info('source called');
          sourceCalls++;
        }
      };
      let scope = createScopeForTest(source);

      // overrides updateSource
      binding.bind(scope);
      expect(binding.callSource === originalCallSource).not.toBe(true);

      for (let i = 0, ii = 50; i < ii; i++) {
        button.dispatchEvent(DOM.createCustomEvent('click', { bubbles: true }));
      }

      // How to ensure this happen after all events without timeout?
      let testDuration = 500;
      function endTest() {
        binding.unbind();
        expect(sourceCalls).toEqual(0);
        expect(binding.callSource === originalCallSource).toBe(true);
        callback();
      }
      setTimeout(endTest, testDuration);
    }
開發者ID:aurelia,項目名稱:templating-resources,代碼行數:28,代碼來源:self-binding-behavior.spec.ts

示例2: it

  it('should set focus value to true when element gets focus', () => {
    focus.attached();
    setBindedFocusValue(false);

    element.dispatchEvent(DOM.createCustomEvent('focus'));

    expect(focus.value).toBe(true);
  });
開發者ID:aurelia,項目名稱:templating-resources,代碼行數:8,代碼來源:focus.spec.ts

示例3: it

  it('should apply update trigger events', () => {
    let source = { foo: 'bar' };
    let scope = createScopeForTest(source);
    let target = document.createElement('input');
    let bindingExpression = bindingEngine.createBindingExpression('value', `foo & updateTrigger:'blur':'paste'`, bindingMode.twoWay, lookupFunctions);
    let binding = bindingExpression.createBinding(target);

    binding.bind(scope);
    let targetHandler = binding.targetObserver.handler;

    target.value = 'baz';
    target.dispatchEvent(DOM.createCustomEvent('change'));
    expect(source.foo).toBe('bar');
    target.dispatchEvent(DOM.createCustomEvent('blur'));
    expect(source.foo).toBe('baz');

    target.value = 'bang';
    target.dispatchEvent(DOM.createCustomEvent('change'));
    expect(source.foo).toBe('baz');
    target.dispatchEvent(DOM.createCustomEvent('paste'));
    expect(source.foo).toBe('bang');


    binding.unbind();

    target.value = 'target';
    target.dispatchEvent(DOM.createCustomEvent('blur'));
    expect(source.foo).toBe('bang');
    target.dispatchEvent(DOM.createCustomEvent('paste'));
    expect(source.foo).toBe('bang');

    // also makes sure we disposed the listeners
    expect(targetHandler.element).toBe(null);
  });
開發者ID:aurelia,項目名稱:templating-resources,代碼行數:34,代碼來源:update-trigger-binding-behavior.spec.ts

示例4: it

  it('should debounce call source', () => {
    let target = document.createElement('div');
    let delay = 150;
    let bindingExpression = new (AureliaBinding as any).ListenerExpression(
      bindingEngine.observerLocator.eventManager,
      'mousemove',
      bindingEngine.parseExpression(`handleMouseMove($event) & debounce:${delay}`),
      delegationStrategy.none,
      false,
      lookupFunctions
    );

    let binding = bindingExpression.createBinding(target);
    let originalCallSource = binding.callSource;

    let viewModel = {
      callCount: 0,
      handleMouseMove: e => {
        viewModel.callCount++;
      }
    };
    let scope = createScopeForTest(viewModel);

    // overrides callSource
    binding.bind(scope);
    expect(binding.callSource === originalCallSource).not.toBe(true);

    let exerciseCount = 10;
    let callCount = 0;
    while (exerciseCount--) {
      let tick = Math.floor(Math.random() * delay + delay / 3);
      let shouldCall = tick >= delay;

      target.dispatchEvent(DOM.createCustomEvent('mousemove'));
      jasmine.clock().tick(tick);

      callCount += Number(shouldCall);
    }

    expect(callCount).toBe(viewModel.callCount);
    binding.unbind();
    expect(binding.callSource === originalCallSource).toBe(true);
  });
開發者ID:aurelia,項目名稱:templating-resources,代碼行數:43,代碼來源:debounce-binding-behavior.spec.ts

示例5: change

export function change(element: HTMLInputElement, value: string): Promise<void> {
  element.value = value;
  element.dispatchEvent(DOM.createCustomEvent('change', { bubbles: true }));
  return new Promise<void>(setTimeout);
}
開發者ID:manuel-guilbault,項目名稱:aurelia-validation,代碼行數:5,代碼來源:shared.ts

示例6: blur

export function blur(element: Element): Promise<void> {
  element.dispatchEvent(DOM.createCustomEvent('blur', {}));
  return new Promise<void>(setTimeout);
}
開發者ID:manuel-guilbault,項目名稱:aurelia-validation,代碼行數:4,代碼來源:shared.ts

示例7: setInterval

 let updateSourceInterval = setInterval(() => {
   // console.info('dispatching');
   target.dispatchEvent(DOM.createCustomEvent('mousemove'));
 }, 20);
開發者ID:aurelia,項目名稱:templating-resources,代碼行數:4,代碼來源:throttle-binding-behavior.spec.ts


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