deadmau5v 2024-05-09 08:45 采纳率: 50%
浏览 15

TypeScript 变量类型声明问题

准备实现一下 井字旗 https://react.docschina.org/learn/tutorial-tic-tac-toe 遇到这个问题

import "./App.less"
import {useState} from "react";


function Square(onclickCallBack: ????) {                    // <<------------- 这里怎么写类型
    const [content, contentSetter] = useState("")
    return (
        <button className="square" onClick={() => {
            onclickCallBack(contentSetter)
        }}>{content}</button>
    )
}

function App() {
    const [square, squareSetter] = useState("X")

    function change(f: (c: string) => void): void {
        f(square)
        square === "X" ? squareSetter("O") : squareSetter("X")
    }

    return (
        <div id="main">
            <div className="board-row">
                <Square onclickCallBack={change}/>
                <Square onclickCallBack={change}/>
                <Square onclickCallBack={change}/>
            </div>
            <div className="board-row">
                <Square onclickCallBack={change}/>
                <Square onclickCallBack={change}/>
                <Square onclickCallBack={change}/>
            </div>
            <div className="board-row">
                <Square onclickCallBack={change}/>
                <Square onclickCallBack={change}/>
                <Square onclickCallBack={change}/>
            </div>
        </div>
    )
}

export default App;
  • 写回答

3条回答 默认 最新

  • 笑面虎 2024-05-09 08:45
    关注

    以下内容由CHATGPT及笑面虎共同生成、有用望采纳:


    【问题概括】:这个问题的目的是要为 React 组件中的 onclickCallBack 函数定义正确的 TypeScript 类型,以确保函数的使用符合预期。

    【问题出现原因】:在 TypeScript 中,当定义函数参数时,需要指定参数的类型。在提供的代码中,onclickCallBack 参数是一个函数,但是没有指定这个函数的参数类型和返回值类型,这导致了类型声明的问题。

    【问题解决方案】:为了解决这个问题,我们需要定义 onclickCallBack 参数的类型,使其成为一个接受一个特定类型参数并且不返回任何值(void)的函数。在这个场景中,onclickCallBack 应该是一个接受一个函数为参数的函数,这个函数参数本身接受一个 string 类型的参数并返回 void

    【提供代码】:以下是修改后的代码,其中 onclickCallBack 参数被赋予了正确的类型声明:

    import "./App.less";
    import { useState } from "react";
    
    // 定义 Square 组件的 props 类型,包括一个函数类型的属性 onclickCallBack
    interface SquareProps {
      onclickCallBack: (newContentSetter: (newContent: string) => void) => void;
    }
    
    function Square(props: SquareProps) {
      const [content, contentSetter] = useState("");
      return (
        <button
          className="square"
          onClick={() => {
            // 调用传入的函数,同时传递 contentSetter 作为参数
            props.onclickCallBack((newContent: string) => {
              contentSetter(newContent);
            });
          }}
        >
          {content}
        </button>
      );
    }
    
    function App() {
      const [square, squareSetter] = useState(["", "", "", "", "", "", "", "", ""]);
    
      const change = (index: number, newContent: string): void => {
        const newSquares = [...square];
        newSquares[index] = newContent;
        squareSetter(newSquares);
      };
    
      return (
        <div id="main">
          <div className="board-row">
            <Square onclickCallBack={(index) => change(index, "X")} />
            <Square onclickCallBack={(index) => change(index, "X")} />
            <Square onclickCallBack={(index) => change(index, "X")} />
          </div>
          {/* ... 其他棋盘行 ... */}
        </div>
      );
    }
    
    export default App;
    

    【代码运行方式】:这段代码应该在一个 React 项目中运行,你需要有 Node.js 和 npm(或 yarn)安装在你的开发环境中。首先,使用 create-react-app 创建一个新的 React 项目,然后将这段代码替换到项目的 App.tsx 文件中。之后,运行 npm startyarn start 来启动开发服务器并查看结果。

    【代码预期运行结果】:代码将渲染一个井字棋游戏的界面,每个按钮点击后会轮流显示 "X" 或 "O"。

    【推荐相关链接】:

    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 5月9日

悬赏问题

  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境
  • ¥30 关于#java#的问题,请各位专家解答!