首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >反应本机构造函数:意料之外的标记,预期;

反应本机构造函数:意料之外的标记,预期;
EN

Stack Overflow用户
提问于 2020-04-21 04:40:15
回答 2查看 3.5K关注 0票数 1

我是新的反应本机,我面临一些关于语法错误的问题,我在这里给我的app.js

代码语言:javascript
复制
import React from 'react';
import { StyleSheet, Text, View } from 'react-native';
import MainService from './App/mainservice';

export default function App() {
  state ={
   loaded:false
  }
  constructor() {
   super();
   MainService.load(v =>this.setState({loaded:true}));
  }

  return (
    <View style={styles.container}>
      {this.state.loaded ? <Text>Open up App.js to start working on your app!</Text> : <Text> Loading..</Text>}
    </View>
  );
}

constructor() {的这一行中发生的错误,表示构造函数丢失了一个错误,

代码语言:javascript
复制
TransformError SyntaxError: C:\Users\Zeed Tanue\Desktop\Skills\vue-native\React\deleteLater\App.js: Unexpected token, expected ";" (9:16)

   7 |     loaded:false
   8 |   }

>  9 |   constructor() {
     |                 ^
  10 |     super();
  11 |     MainService.load(v =>this.setState({loaded:true}));
  12 |   }

我已经做了一些研究,但没有找到任何解决方案,这是正确的方法,在每一个解决方案,因此我有错误。你能帮我解决这个问题吗?为什么会这样?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-04-21 04:52:02

React函数(功能组件)没有constructor,也没有this,它们是不存在的。您可以使用useStateuseEffect挂钩来提供状态和组件生命周期的感觉。

代码语言:javascript
复制
import React, { useEffect, useState} from 'react';
import { StyleSheet, Text, View } from 'react-native';
import MainService from './App/mainservice';

export default function App() {
  const [loaded, setLoaded] = useState(false); // provide initial false state

  useEffect(() => {
    MainService.load(v => setLoaded(true));
  }, []); // empty dependency array analogous to componentDidMount

  return (
    <View style={styles.container}>
      {loaded ? (
        <Text>Open up App.js to start working on your app!</Text>
      ) : (
        <Text>Loading...</Text>}
      )
    </View>
  );
}

如果您想使它成为一个基于类的组件,那么下面是您遇到的问题。不能在构造函数中调用setState,因此需要在生命周期函数中调用MainService,比如componentDidMount。此外,呈现的JSX需要在render生命周期函数中返回。

代码语言:javascript
复制
import React, { Component } from 'react';
import { StyleSheet, Text, View } from 'react-native';
import MainService from './App/mainservice';

export default class App extends Component {
  constructor() {
    super();
    this.state ={
      loaded:false
    }
  }

  componentDidMount() {
    MainService.load(v =>this.setState({loaded:true}));
  }

  render() {
    const { loaded } = this.state;
    return (
      <View style={styles.container}>
        {loaded ? (
          <Text>Open up App.js to start working on your app!</Text>
        ) : (
          <Text>Loading...</Text>}
        )
      </View>
    );
  }
}
票数 3
EN

Stack Overflow用户

发布于 2020-04-21 04:42:52

不要尝试这个-尝试接受的答案而不是

试试这个吧。有关解释,请参见代码注释。

代码语言:javascript
复制
import React from 'react';
import { StyleSheet, Text, View } from 'react-native';
import MainService from './App/mainservice';

export default function App() {
  constructor(props) { // Must accept props arg
   super(props); // Must pass props to super()
   this.state = { // If you define a constructor, any initial state you have should be defined within the constructor
     loaded: false
   }
   MainService.load(v =>this.setState({loaded:true}));
  }

return (
 <View style={styles.container}>
  {this.state.loaded ? <Text>Open up App.js to start working on your app!</Text> : <Text> Loading..</Text>}
</View>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61336071

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档