反应-通过useContext在组件中使用状态

时间:2020-06-23 18:14:44

标签: reactjs

你好,我在使用钩子创建应用程序时卡住了 我不为什么,但是我的组件没有从我的上下文组件下载状态,或者我的初始状态没有正确更新。有人知道发生了什么吗?

上下文组件:

import React, { createContext, useState } from 'react';

export const WeatherDataContext = createContext();

const WeatherDataContextProvider = (props) => {
    const [weather, setWeather] = useState(
        {
            city: null,
            temp: null
        }
    )
    const addWeather = (city, temp) => {
        setWeather({
            city,
            temp
        })
    }
    
    return (
        <WeatherDataContext.Provider value={{weather, addWeather}}>
            {props.children}
        </WeatherDataContext.Provider>
    )
}

export default WeatherDataContextProvider

表格-axios-组件:

import React, {useContext, useState} from 'react';
import { WeatherDataContext } from '../context/WeatherDataContext';
import axios from 'axios'
import {Link} from 'react-router-dom'


const WeatherForm = () => {
    const {addWeather} = useContext(WeatherDataContext);
    const [value, setValue] = useState('')

    const handleChange = (e) => {
        e.preventDefault();
        axios.get(`https://api.openweathermap.org/data/2.5/weather?q=${value}&appid=${KEY}&units=metric`)
            .then(res => {
                
                
               addWeather(res.data.name, res.data.main.temp)
                
            })
      
    }

    return (
        <div class='weather-form'>
            <form onSubmit={handleChange}>
                <input placeholder='City' onChange={(e) => setValue(e.target.value)} value={value} required/>
                <Link to='/weather'><button>Search</button></Link>
                
            </form>
        </div>
    )
}

export default WeatherForm

我要使用更新状态的最后一个组件

import React, {useContext, useState} from 'react';
import { WeatherDataContext } from '../context/WeatherDataContext';

const WeatherFront = () => {
    const {weather} = useContext(WeatherDataContext)
    
    console.log(weather)
    return (
        <div class='weather-front'>
            <h1>City: {weather.city}, Temperatura: {weather.temp}</h1>
        </div>
    )
}

export default WeatherFront

1 个答案:

答案 0 :(得分:0)

您的按钮未提交表单-而是从页面导航。 因此handleChange没有被调用。

您可以通过按钮onClick而不是表单onSubmit来调用它。请确保随后省略e.preventDefault(),以便父链接仍然可以导航。

const WeatherForm = () => {
  const { addWeather } = useContext(WeatherDataContext)
  const [value, setValue] = useState('')

  const handleChange = (e) => {
    axios.get(`https://api.openweathermap.org/data/2.5/weather?q=${value}&appid=${KEY}&units=metric`)
            .then(res => {
                
                
               addWeather(res.data.name, res.data.main.temp)
                
            })
  }

  return (
    <div class="weather-form">
      <form >
        <input
          placeholder="City"
          onChange={(e) => setValue(e.target.value)}
          value={value}
          required
        />
        <Link to="/weather">
          <button onClick={handleChange}>Search</button>
        </Link>
      </form>
    </div>
  )
}

请确保将两个页面包装在同一个上下文中:

<WeatherDataContextProvider>
        <Router>
          <Switch>
            <Route path="/weather">
              <WeatherFront></WeatherFront>
            </Route>
            <Route path="/">
              <WeatherForm></WeatherForm>
            </Route>
          </Switch>
        </Router>
</WeatherDataContextProvider>