复制了这两个组件代码后依然报错

正在回答 回答被采纳积分+1

登陆购买课程后可参与讨论,去登陆

2回答
好帮手慕星星 2022-04-20 18:12:41

同学你好,这边测试是react版本的问题,现在安装react版本是18,课程中安装的react版本是17,可能改变后写法上有点问题。

做的测试有:替换掉package.json文件中的所有插件再重新安装,是不可以的,会报其他错误。

这边目前无法解决,需要与讲师沟通。建议同学使用课程中初始的项目完成后面内容

https://img1.sycdn.imooc.com//climg/625fdc610960d9f109030081.jpg

https://img1.sycdn.imooc.com//climg/625fdc760917129b05360360.jpg

有办法解决后会与立即回复同学的。

好帮手慕星星 2022-04-20 11:55:26

同学你好,建议将鼠标移入波浪线处,将报错提示粘贴上来。另外也建议将这两个组件代码粘贴上来,不要截图,便于帮助测试。

祝学习愉快!

  • 提问者 weixin_慕丝2377090 #1

    index:


    import React from "react";

    import ReactDOM from "react-dom";

    import "./index.css";

    import App from "./App";

    import reportWebVitals from "./reportWebVitals";

    import { AppStateProvider } from "./AppState";


    ReactDOM.render(

    <React.StrictMode>

    <AppStateProvider>

    <App />

    </AppStateProvider>

    </React.StrictMode>,

    document.getElementById("root")

    );


    // If you want to start measuring performance in your app, pass a function

    // to log results (for example: reportWebVitals(console.log))

    // or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals

    reportWebVitals();


    报错:

    https://img1.sycdn.imooc.com//climg/625f8cba09e5f7a911540228.jpg

    2022-04-20 12:31:56
  • 提问者 weixin_慕丝2377090 #2

    AppState

    import React, { useState } from "react";


    // 1.0: 使用TS接口对 全局的上下文对象 内容进行规范。

    //      内容 —— username

    //          —— 购物车[] : 每个 item {} 内容是 ID 和 名字

    interface AppStateValue {

    username: string;

    shoppingCart: { items: { id: number; name: string }[] };

    }


    // 1.1: 全局的上下文对象(默认值)

    const defaultContextValue: AppStateValue = {

    username: "Ernest",

    shoppingCart: { items: [] },

    };

    // 1.2: 创建全局的上下文对象

    export const appContext = React.createContext(defaultContextValue);


    // 2.2: 由于涉及全局状态state的更新,需要使用setState

    //      因为初始化的是一个函数,所以传入undefined作为初始化值。

    //      由于初始化传入的是undefined,所以 React.createContext时候需要规范类型

    //      类型是: <setState函数的类型|undefined>

    // appSetStateContext 定义的是一个函数,是一个混合类型,而它的初始化为undefined。

    export const appSetStateContext = React.createContext<

    React.Dispatch<React.SetStateAction<AppStateValue>>

    | undefined>(undefined);


    // 2.0: 全局状态组件

    //      函数式组件,该组件是高阶组件,功能就是把所有他的子组件包裹起来。并且从全局角度提供数据支持。

    //      所以,它的返回值(渲染内容)是 Provider 包裹的 子组件(这些子组件是 被动态传入的,使用props接收到)。

    //     (只要是被provider包裹住的组件,不管相差多少层级都可以实现直接数据传递)

    //      类似 Vue <Fregarment>

    export const AppStateProvider: React.FC = (props) => {


    // 2.1: 使用useState hooks,

    //      使用上下文数据默认值 初始化组件状态,

    //      这个组件状态:state 会用于做 provider的value 属性,这样就可以被作为provider.value使用。

    //      <appContext.Provider value = {}>


    //    : 因为操作是购物车,会涉及全局state的更新,所以需要把 全局state对应的setter(setState函数)也共享。

    //      为了可以共享setState函数,需要创建对应的上下文context,来连接setState函数。appSetStateContext.

    //      <appSetStateContext.Provider value={}>  setState函数就可以被作为provider.value使用

    const [state, setState] = useState(defaultContextValue);


    return (

    <appContext.Provider value={state}>

    <appSetStateContext.Provider value={setState}>

    {props.children}

    </appSetStateContext.Provider>

    </appContext.Provider>

    );

    };



    报错:https://img1.sycdn.imooc.com//climg/625f8cf509ac9ce708460192.jpg

    2022-04-20 12:33:00
  • 提问者 weixin_慕丝2377090 #3

    index


    import React from "react";

    import ReactDOM from "react-dom";

    import "./index.css";

    import App from "./App";

    import reportWebVitals from "./reportWebVitals";

    import { AppStateProvider } from "./AppState";


    ReactDOM.render(

    <React.StrictMode>

    <AppStateProvider>

    <App />

    </AppStateProvider>

    </React.StrictMode>,

    document.getElementById("root")

    );


    // If you want to start measuring performance in your app, pass a function

    // to log results (for example: reportWebVitals(console.log))

    // or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals

    reportWebVitals();



    报错:https://img1.sycdn.imooc.com//climg/625f8d4c09499ae312120310.jpg

    2022-04-20 12:34:24
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师