本文整理匯總了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);
});
示例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']);
});
示例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);
});
示例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);
});