在 NextJS 中使用 useState 对象时 Context 对象为空
Context object is empty when using useState object in NextJS
我正在尝试在 NextJS 中传递上下文对象,该对象使用来自 useState 挂钩的数据,但状态变量和 setState 函数在使用时未定义。这很奇怪,因为当我在其位置传递一个简单变量时,它工作正常,只有在使用 useState 时它才未定义。所以我知道上下文对象在工作,但 useState 挂钩没有。
我的 _app.js
文件:
import React from 'react';
import App from 'next/app';
import Head from 'next/head';
import Aux from '../hoc/Aux';
import ContextProvider from '../context/context';
class MyApp extends App {
render() {
const { Component, pageProps } = this.props;
return (
<Aux>
<Head>
<title>MyApp</title>
</Head>
<ContextProvider>
<Component {...pageProps} />
</ContextProvider>
</Aux>
);
};
};
export default MyApp;
我的 context.js
文件:
import React, { createContext, useState } from 'react';
export const Context = createContext();
const ContextProvider = (props) => {
const [ activeTab, setActiveTab ] = useState('OVERVIEW');
return (
<Context.Provider value={{ activeTab, setActiveTab }}>
{props.children}
</Context.Provider>
);
};
export default ContextProvider;
我的 nav.js
文件:
import styled from 'styled-components';
import { Context } from '../../context/context';
import { useContext } from 'react';
const Nav = () => {
const [activeTab, setActiveTab] = useContext(Context);
const TourNavUl = styled.ul`
`;
const TourNavLi = styled.li`
`;
return (
<NavUl>
<NavLi>
<span onClick={() => setActiveTab('OVERVIEW')}>Overview</span>
</NavLi>
<NavLi>
<span onClick={() => setActiveTab('ITINERARY')}>Itinerary</span>
</NavLi>
<NavLi>
<span onClick={() => setActiveTab('DETAILS')}>Details</span>
</NavLi>
<NavLi>
<span onClick={() => setActiveTab('BOOKINGS')}>Bookings</span>
</NavLi>
</NavUl>
);
};
export default Nav;
这将返回错误 TypeError: setActiveTab is not a function
,因为它未定义。正如我之前所说,如果我通过上下文传递一个简单变量,它工作正常,所以我知道它设置正确,但状态没有通过上下文对象传递。
我对状态做错了什么?
useContext
返回一个对象,而不是数组。
而不是这个
const [activeTab, setActiveTab] = useContext(Context);
你应该有这个:
const {activeTab, setActiveTab} = useContext(Context);
我正在尝试在 NextJS 中传递上下文对象,该对象使用来自 useState 挂钩的数据,但状态变量和 setState 函数在使用时未定义。这很奇怪,因为当我在其位置传递一个简单变量时,它工作正常,只有在使用 useState 时它才未定义。所以我知道上下文对象在工作,但 useState 挂钩没有。
我的 _app.js
文件:
import React from 'react';
import App from 'next/app';
import Head from 'next/head';
import Aux from '../hoc/Aux';
import ContextProvider from '../context/context';
class MyApp extends App {
render() {
const { Component, pageProps } = this.props;
return (
<Aux>
<Head>
<title>MyApp</title>
</Head>
<ContextProvider>
<Component {...pageProps} />
</ContextProvider>
</Aux>
);
};
};
export default MyApp;
我的 context.js
文件:
import React, { createContext, useState } from 'react';
export const Context = createContext();
const ContextProvider = (props) => {
const [ activeTab, setActiveTab ] = useState('OVERVIEW');
return (
<Context.Provider value={{ activeTab, setActiveTab }}>
{props.children}
</Context.Provider>
);
};
export default ContextProvider;
我的 nav.js
文件:
import styled from 'styled-components';
import { Context } from '../../context/context';
import { useContext } from 'react';
const Nav = () => {
const [activeTab, setActiveTab] = useContext(Context);
const TourNavUl = styled.ul`
`;
const TourNavLi = styled.li`
`;
return (
<NavUl>
<NavLi>
<span onClick={() => setActiveTab('OVERVIEW')}>Overview</span>
</NavLi>
<NavLi>
<span onClick={() => setActiveTab('ITINERARY')}>Itinerary</span>
</NavLi>
<NavLi>
<span onClick={() => setActiveTab('DETAILS')}>Details</span>
</NavLi>
<NavLi>
<span onClick={() => setActiveTab('BOOKINGS')}>Bookings</span>
</NavLi>
</NavUl>
);
};
export default Nav;
这将返回错误 TypeError: setActiveTab is not a function
,因为它未定义。正如我之前所说,如果我通过上下文传递一个简单变量,它工作正常,所以我知道它设置正确,但状态没有通过上下文对象传递。
我对状态做错了什么?
useContext
返回一个对象,而不是数组。
而不是这个
const [activeTab, setActiveTab] = useContext(Context);
你应该有这个:
const {activeTab, setActiveTab} = useContext(Context);