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


TypeScript react-mixout.default函數代碼示例

本文整理匯總了TypeScript中react-mixout.default函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript default函數的具體用法?TypeScript default怎麽用?TypeScript default使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


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

示例1: it

  it('should properly listen on window events as default', () => {
    let clicks = 0;
    const Test = buildClass(() => clicks++);
    const Mixout = mixout(listen('click', 'onClick'))(Test);
    mount(React.createElement(Mixout));

    document.body.click();
    expect(clicks).to.be.equals(1);
    document.body.click();
    document.body.click();
    expect(clicks).to.be.equals(3);
  });
開發者ID:alitaheri,項目名稱:react-mixout,代碼行數:12,代碼來源:main.spec.ts

示例2: onClick

  it('should properly pass down useCapture', () => {
    const calls: string[] = [];
    let b: any;

    class Test extends React.Component<any, any> {
      public onClick() {
        calls.push('test');
      }

      public render() {
        return React.createElement('button', {
          onClick: () => calls.push('button'),
          ref: (i: any) => b = i,
        });
      }
    }

    const element = document.createElement('div');
    document.body.appendChild(element);

    const Mixout = mixout(listen('click', 'onClick', { target: 'document', useCapture: true }))(Test);
    mount(React.createElement(Mixout), { attachTo: element });

    expect(calls).to.deep.equal([]);
    b.click();
    expect(calls).to.deep.equal(['test', 'button']);
  });
開發者ID:alitaheri,項目名稱:react-mixout,代碼行數:27,代碼來源:main.spec.ts

示例3: it

  it('should call resolver only when selectors return a different value', () => {
    let called = 0;
    const memo = memoize(
      'result',
      (_p, context) => context.pocket.cash,
      (_p, context) => context.pocket.coins,
      props => props.accounting.credit,
      props => props.accounting.debt,
      (cash, coins, credit, debt) => { called++; return cash + coins + credit - debt; },
    );

    const Mixout = mixout(memo)(Test);
    const wrapper = mount(
      React.createElement(Mixout, { accounting: { credit: 100, debt: 50 } }),
      {
        childContextTypes: { pocket: () => null },
        context: { pocket: { cash: 1, coins: 10 } },
      },
    );

    expect(wrapper.find(Test).at(0).prop('result')).to.be.equals(61);
    expect(called).to.be.equals(1);

    wrapper.setProps({ accounting: { credit: 100, debt: 50 } });
    wrapper.setContext({ pocket: { cash: 1, coins: 10 } });

    expect(wrapper.find(Test).at(0).prop('result')).to.be.equals(61);
    expect(called).to.be.equals(1);

    wrapper.setContext({ pocket: { cash: 2, coins: 10 } });

    expect(wrapper.find(Test).at(0).prop('result')).to.be.equals(62);
    expect(called).to.be.equals(2);

    wrapper.setProps({ accounting: { credit: 100, debt: 60 } });
    wrapper.setContext({ pocket: { cash: 2, coins: 10 } });

    expect(wrapper.find(Test).at(0).prop('result')).to.be.equals(52);
    expect(called).to.be.equals(3);

    wrapper.setProps({ accounting: { credit: 100, debt: 50 } });
    wrapper.setContext({ pocket: { cash: 2, coins: 20 } });

    expect(wrapper.find(Test).at(0).prop('result')).to.be.equals(72);
    expect(called).to.be.equals(5);

    wrapper.setProps({ accounting: { credit: 100, debt: 50 } });
    wrapper.setContext({ pocket: { cash: 2, coins: 20 } });

    expect(wrapper.find(Test).at(0).prop('result')).to.be.equals(72);
    expect(called).to.be.equals(5);

  });
開發者ID:alitaheri,項目名稱:react-mixout,代碼行數:53,代碼來源:main.spec.ts

示例4: it

  it('should not re-render if previous and next props are shallowly equal', () => {
    let renders = 0;
    const Component = () => { renders++; return null!; };
    const Mixout = mixout(pure)(Component);

    const wrapper = mount(React.createElement(Mixout, { prop: 'foo' }));
    expect(renders).to.be.equals(1);

    wrapper.setProps({ prop: 'bar' });
    expect(renders).to.be.equals(2);

    wrapper.setProps({ prop: 'foo' });
    expect(renders).to.be.equals(3);

    wrapper.setProps({ prop: 'foo' });
    wrapper.setProps({ prop: 'foo' });
    expect(renders).to.be.equals(3);
  });
開發者ID:alitaheri,項目名稱:react-mixout,代碼行數:18,代碼來源:main.spec.ts


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