开发者问题收集

为什么我收到无法读取未定义的属性“状态”?

2019-06-24
89

我有一个构造函数突然停止工作,不知道为什么。

我有这些数据。如果你看到第 24 行,这是读出的,实际上返回了包括道具在内的各种项目。然而,1 行之后,当我尝试写入状态时,它返回此错误。我不知道为什么,因为这里没有什么可绑定的,而且它在某个时候还在工作。

TypeError: Cannot read property 'state' of undefined
 23 | super(props);
 24 | console.log(this)
 25 | 
 26 | this.state = {
    | ^  27 |   loading: true,
 28 |   ...props.location.state,
 29 |   review: props.review,
import React, { Component } from 'react';

import { withFirebase } from '../Firebase';
import { AuthUserContext } from '../Session';

import { needsEmailVerification } from '../Session/withEmailVerification.js'

import NewCommentReactionPage from '../Comments/newReaction.js'
import NewReviewFeedbackPage from '../Comments/new.js'
import RequireEmailComponent from '../Errors/requireEmail.js'

const ReviewFeedbackPage = (props) => (
  <AuthUserContext.Consumer>
    {authUser => (
        <ReviewFeedbackMain authUser={authUser} isLoggedIn={condition(authUser)} needEmail={needsEmailVerification(authUser)} {...props} />
    )}
  </AuthUserContext.Consumer>
);

class ReviewFeedbackBase extends Component {
  constructor(props) {
    super(props);

    this.state = {
      loading: true,
      ...props.location.state,
      review: props.review,
      newComment: '',
      comments: [],
      reactions: props.review ? props.review.count ? props.review.count.reactions ?  props.review.count.reactions : {} : {} : {}
    };

    this.reactionAdded = this.reactionAdded.bind(this)
    this.commentAdded = this.commentAdded.bind(this)
  }


  componentDidMount() {
    ...  
  }

  componentDidUpdate(prevProps, prevState) {
    ...
  }


  commentAdded(newComment){
 ...
 }

  render() {
    const { review, comments, reactions } = this.state;
    const { isLoggedIn, needsEmail } = this.props;
    return (
      <div>
       ....
        }
        {isLoggedIn && needsEmail && <RequireEmailComponent toAction={{text: 'to react'}} />}
        {isLoggedIn && !needsEmail &&
          <div>
            <NewCommentReactionPage review={review} reactionAdded={this.reactionAdded} />
            <NewReviewFeedbackPage review={review} commentAdded={this.commentAdded} />
          </div>
        }


      </div>
    );
  }
}

const ReviewFeedbackMain = withFirebase(ReviewFeedbackBase);

const condition = authUser => !!authUser;
export default ReviewFeedbackPage;
1个回答

在您的代码中,您有 2 个 state

this.state = {  // declaring state
  loading: true,
  ...props.location.state,  // referencing the state of ...props.location
  review: props.review,
  newComment: '',
  comments: [],
  reactions: props.review ? props.review.count ? props.review.count.reactions ?  props.review.count.reactions : {} : {} : {}
};

您收到此错误是因为 props.locationundefined 并且您尝试从中访问 state

错误出现在第 26 行,因为它无法声明变量。

26 | this.state = {
   | ^  27 |   loading: true,

问题不在于构造函数,而在于 ...props.location.state

现在您知道问题是什么了,您需要看看您想要做什么。

在传播 props.location.state 之前,也许可以做一些检查?这取决于您。

Vencovsky
2019-06-24