本文整理匯總了TypeScript中mobx.Reaction類的典型用法代碼示例。如果您正苦於以下問題:TypeScript Reaction類的具體用法?TypeScript Reaction怎麽用?TypeScript Reaction使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Reaction類的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: function
target.componentWillMount = function() {
// Call original
baseWillMount && baseWillMount.call(this);
let reaction: Reaction;
let isRenderingPending = false;
const initialName = this.displayName || this.name || (this.constructor && (this.constructor.displayName || this.constructor.name)) || '<component>';
const baseRender = this.render.bind(this);
const initialRender = (nextProps, nextContext) => {
reaction = new Reaction(`${initialName}.render()`, () => {
if (!isRenderingPending) {
isRenderingPending = true;
if (this.__$mobxIsUnmounted !== true) {
let hasError = true;
try {
Component.prototype.forceUpdate.call(this);
hasError = false;
} finally {
if (hasError) {
reaction.dispose();
}
}
}
}
});
reactiveRender.$mobx = reaction;
this.render = reactiveRender;
return reactiveRender(nextProps, nextContext);
};
const reactiveRender: IReactiveRender = (nextProps, nextContext) => {
isRenderingPending = false;
let rendering = undefined;
reaction.track(() => {
if (isDevtoolsEnabled) {
this.__$mobRenderStart = Date.now();
}
rendering = extras.allowStateChanges(false, baseRender.bind(this, nextProps, nextContext));
if (isDevtoolsEnabled) {
this.__$mobRenderEnd = Date.now();
}
});
return rendering;
};
this.render = initialRender;
};
示例2: Reaction
reaction = new Reaction(`${initialName}.render()`, () => {
if (!isRenderingPending) {
isRenderingPending = true;
if (this.__$mobxIsUnmounted !== true) {
let hasError = true;
try {
Component.prototype.forceUpdate.call(this);
hasError = false;
} finally {
if (hasError) {
reaction.dispose();
}
}
}
}
});
示例3:
b.init(() => {
var res: b.IBobrilChildren;
reaction.track(() => {
res = counter.get();
});
return res;
});
示例4:
const reactiveRender: IReactiveRender = (nextProps, nextContext) => {
isRenderingPending = false;
let rendering = undefined;
reaction.track(() => {
if (isDevtoolsEnabled) {
this.__$mobRenderStart = Date.now();
}
rendering = extras.allowStateChanges(false, baseRender.bind(this, nextProps, nextContext));
if (isDevtoolsEnabled) {
this.__$mobRenderEnd = Date.now();
}
});
return rendering;
};