TypeError: undefined is not a function (near '...this.state.profile.map...')

时间:2021-02-16 15:18:36

标签: javascript reactjs react-native

我一次又一次地出错。我不知道为什么会出现此错误。

我得到的响应也是一个数组,我尝试使用 console.log 。下面是证明

来自 axios Api 的响应:

{

"CCompany": "Testing Company", 
"CFName": "Rehan", 
"CLName": "ahmed", 
"CMName": "", 
"CTelHome": "1-232-2323232", 
"UID": "700002"

}

代码如下:

import React, { Component } from 'react';

import { View, Text, Dimensions, BackHandler, ToastAndroid } from 'react-native';

import axios from 'axios';

import Card from './Card';

import CardSection from './CardSection';

import ProfileDetails from './ProfileDetails';

import AsyncStorage from '@react-native-community/async-storage';



// Create a component

class ProfileActivity extends Component {

    constructor() {
        super();

        this.state = {
            profile: [],
            setUID: '',
            isloading: true,
        };
    }

    state = {
        canBeClosed: false
    }


    componentWillUnmount() {
        BackHandler.removeEventListener('hardwareBackPress', this.handleBackButton);
    }

    handleBackButton = () => {
        if (this.props.navigation.isFocused()) {
            if (this.state.canBeClosed)
                return this.state.canBeClosed = false;

            else {
                setTimeout(() => { this.state.canBeClosed = false }, 3000);
                ToastAndroid.show("Press Again To Exit !", ToastAndroid.LONG);

                return this.state.canBeClosed = true
            }
        }
    };

    async componentDidMount() {
       
        try {
            if (this.state.setUID == null && this.state.profile == null) {
                console.log('profile remove');

                const user = await AsyncStorage.getItem('responseJson');
                const parsed = JSON.parse(user);
                if (parsed !== null) {
                    this.setState({ setUID: parsed.UID });
                }
               
                axios.get('https:/new.didx.net/didxapi/UserInfo.php?UID=' + this.state.setUID)
                    .then(response => this.setState({ profile: response.data }));
            }
            else {
                this.setState({ setUID: "" });
                this.setState({ profile: "" });
                console.log('not remove');
                const user = await AsyncStorage.getItem('responseJson');
                const parsed = JSON.parse(user);
                if (parsed !== null) {
                    this.setState({ setUID: parsed.UID });
                }
               
                axios.get('https:/new.didx.net/didxapi/UserInfo.php?UID=' + this.state.setUID)
                    .then(response => this.setState({ profile: response.data }));
            }
        }
        catch (error) {
            alert('Server Error!')
        }

        BackHandler.addEventListener('hardwareBackPress', this.handleBackButton);
       

    }

    renderProfile() {
        if (this.state.profile) {
            console.log(this.state.profile);
            return this.state.profile.map(profile => (
                <ProfileDetails  key={profile.UID} profile={profile} />
             ));
        }
    }


    render() {
        return (

            <View style={styles.container}>
                {this.renderProfile()}

            </View>
        );
    }
}

export default ProfileActivity;

const h = Dimensions.get('screen').height * 0.01;
const w = Dimensions.get('screen').width * 0.01;


const styles = {
    container: {
        flex: 1,
        backgroundColor: '#fff'
    },
    ViewStyle: {
        paddingTop: h * 5,

    },
    TextStyle: {
        justifyContent: 'flex-start',
        // alignSelf: 'center',
        color: '#000',
        fontWeight: 'bold',
        fontSize: 20,
        padding: 5,
        fontFamily: 'Roboto',
        maxWidth: w * 50,

    }
}

我想尽一切办法解决这个问题。

1 个答案:

答案 0 :(得分:1)

data = pandas.read_csv("mydata.csv",dtype={"CHR":"string"}) 需要一个数组...但您的 .map 调用返回一个 axios.get('https:/new.didx.net/didxapi/UserInfo.php?UID=' + this.state.setUID)object