反应useEffect挂钩与axios无法读取未定义的属性

时间:2020-06-05 03:29:36

标签: reactjs axios react-hooks

这基于本课程https://fullstackopen.com/en/part2/getting_data_from_server的练习2.14。

用户可以选择一个国家,然后将显示该国家首都的天气信息。我的代码给我错误无法读取未定义的属性“温度”

const Weather = ({ city }) => {
const [weatherDetails, setWeatherDetails] = useState([])

useEffect(() => {
    axios.get('http://api.weatherstack.com/current', {
        params: {
            access_key: process.env.REACT_APP_WEATHER_KEY,
            query: city
        }
    }).then(
        (response) => {
            setWeatherDetails(response.data)
        }
    )
}, [city])
console.log('weather', weatherDetails);

return (
    <div>
        <h3>Weather in {city} </h3>
        {weatherDetails.current.temperature}
    </div>
)}

基本上是

{weatherDetails.current.temperature}

使我的代码崩溃。当我确实删除该行时,由于console.log,我能够看到响应,但是有两个连续的日志

weather []
weather {request: {…}, location: {…}, current: {…}}

我发现我的代码发生在这两者之间,并且它试图在数据到达之前就访问数据,但是我不知道该怎么做。

而且,我不知道useEffect()的[city]参数是什么,所以如果有人可以向我解释它的作用,那将是很好的。

编辑:已解决! 将weatherDetail的初始状态设置为null并进行一些条件渲染

if (weatherDetails) {
    return (
        <div>
            <h3>Weather in {capital}</h3>
            {weatherDetails.current.temperature} Celsius
        </div>
    )
} else {
    return (
        <div>
            Loading Weather...
        </div>
    )
}

1 个答案:

答案 0 :(得分:3)

.0最初是一个空数组,因此没有要读取的weatherDetails属性。

使用一些conditional rendering。使用初始空状态,然后检查在更新对象时是否可以访问该对象的其余部分。

current

const Weather = ({ city }) => { const [weatherDetails, setWeatherDetails] = useState(null) // <-- use null initial state useEffect(() => { axios.get('http://api.weatherstack.com/current', { params: { access_key: process.env.REACT_APP_WEATHER_KEY, query: city } }).then( (response) => { setWeatherDetails(response.data) } ) }, [city]) console.log('weather', weatherDetails); return ( <div> <h3>Weather in {capital} </h3> {weatherDetails && weatherDetails.current.temperature} // check that weatherDetails exists before accessing properties. </div> )} 的参数[city]有什么作用?

这是挂钩的依赖项数组。挂钩在每个渲染周期运行,如果依赖项数组中的任何值已更新,它将触发挂钩的回调,在这种情况下,将触发useEffect属性更新时获取天气数据的效果。

useEffect

默认情况下,效果会在每个完成的渲染后运行,但是您可以 选择仅在某些值更改后才触发它们。