安装仪表板后,authProvider将完成其承诺

时间:2018-10-14 13:47:49

标签: reactjs admin-on-rest react-admin

使用[反应管理员]

我有一个customDashboard,它可以验证参数并重定向到名为pages的页面:

class DashBoard extends Component {
    componentDidMount() {
    const { push } = this.props;
    if (!localStorage.getItem("activePage")) {
        push("/pages");
    }
    ...

我还有这个authProvider,它从后端获取身份验证数据:

export default (type, params) => {
if (type === AUTH_LOGIN) {
    const { authResponse } = params;
    const request = new Request('https://localhost:8080/users/auth', {
        method: 'POST',
        body: JSON.stringify({ userID }),
        headers: new Headers({ 'Content-Type': 'application/json' }),
    });
    fetch(request)
        .then(response => {
            if (response.status < 200 || response.status >= 300) {
                throw new Error(response.body);
             }
             return response.json();
        }).then(({ user }) => {
              localStorage.setItem('token', user.token);
              localStorage.setItem('name', user.name);
              localStorage.setItem('email', user.email);
              localStorage.setItem('activePage', user.activePage);
        }).catch((err) => {
              return Promise.reject(err);
        }).finally(() => {
              return Promise.resolve();});
        ...

我精简了代码以仅显示Promises部分。

但是,正如我在console.log中看到的那样,在挂载finally之后,将执行代码的最后一部分“/pages”。而且,在“/pages”中,我检查了后端返回的activePage,这是怎么回事。

“等待”承诺完成的authProvider中缺少什么?

2 个答案:

答案 0 :(得分:2)

尝试使用async/await,遵循以下流程会更容易:

export default async (type, userID) => {
  if (type === AUTH_LOGIN) {
    try  {
      const res =  await fetch('https://localhost:8080/users/auth', {
        method: 'POST',
        body: JSON.stringify({ userID })
        headers: new Headers({ 'Content-Type': 'application/json' }),
      }) // fetch API data

      const { user: { token, name, email, activePage } } = await res.json(); // convert to JSON, from the JSON's user prop, pull out token, name, email, activePage

      localStorage.setItem('token', token);
      localStorage.setItem('name', name);
      localStorage.setItem('email', email);
      localStorage.setItem('activePage', activePage);

    } catch(err) { console.error(err); }
  }
}

答案 1 :(得分:0)

深入研究发现了这个answer,并在代码中做了一些更改。现在可以正常工作了:

  • 默认函数为async,调用auth函数并最后返回Promise。

    // in src/authProvider.js
    export default async (type, params) => {
        if (type === AUTH_LOGIN) {    
            const { authResponse } = params;
            const user = await auth(userID);
            localStorage.setItem('token', user.token);
            if (user.activePage) localStorage.setItem('activePage', user.activePage);
    
            return Promise.resolve();
    
  • auth函数返回一个Promise:

    const auth = async (userID) => {
      const request = new Request('https://localhost:8080/users/auth', {
        method: 'POST',
        body: JSON.stringify({ userID }),
        headers: new Headers({ 'Content-Type': 'application/json' }),
      });
    
      return fetch(request)
        .then(response => {
          if (response.status < 200 || response.status >= 300) {
            throw new Error(response.body);
          }
          return response.json();
        })
        .then(({ user }) => {
          return user;
        });
    }