makeomatic/redux-connect

Handle thrown errors in promise callbacks

Open

#108 创建于 2017年2月23日

在 GitHub 查看
 (4 评论) (3 反应) (0 负责人)JavaScript (550 star) (73 fork)batch import
enhancementhelp wanted

描述

This line of code does not catch errors so instead they get lost in the event loop and the component never gets rendered correctly. Additionally, it's hard to catch and display the error in an isomorphic app.

Something like this would reproduce it:

@asyncConnect([{
  deferred: true,
  promise: () => {
    throw new Error('whoops, this was not supposed to happen');
  },
}])
class SomeComponent extends React.Component {
  ...
}

It should be fixable like this:

let promiseOrResult;
try {
  promiseOrResult = item.promise(rest);
} catch (error) {
  promiseOrResult = Promise.reject(error);
}

贡献者指南