{"type":"rich","author_url":"https://blog.hatena.ne.jp/riku929hr/","url":"https://blog.riku929hr.com/entry/2021/07/04/155432","width":"100%","published":"2021-07-04 15:54:32","description":"\u624b\u756a\u306e\u51e6\u7406 \u3053\u3053\u304b\u3089Board\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u7de8\u96c6\u3057\u3066\u624b\u756a\u3054\u3068\u306bX\u3068O\u3092\u5165\u308c\u66ff\u3048\u3066\u30d7\u30ed\u30c3\u30c8\u3055\u308c\u308b\u3088\u3046\u306b\u3057\u307e\u3059\u3002 \u7de8\u96c6\u5f8c\u306eBoard\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002 const Board: VFC = () => { const [squares, setSquares] = useState<FillSquare[]>(Array(9).fill(null)); const [xIsNext, setXIsNext] = useState<boolean>(true); const handleClick = (i: number): void => { const squaresSl\u2026","html":"<iframe src=\"https://hatenablog-parts.com/embed?url=https%3A%2F%2Fblog.riku929hr.com%2Fentry%2F2021%2F07%2F04%2F155432\" title=\"React Tutorial\u3092 TypeScript\u3068Hooks\u3067\u66f8\u304d\u76f4\u3057\u3066\u307f\u305f\u2463 - rikuto tech blog\" class=\"embed-card embed-blogcard\" scrolling=\"no\" frameborder=\"0\" style=\"display: block; width: 100%; height: 190px; max-width: 500px; margin: 10px 0px;\"></iframe>","categories":["React\u30c1\u30e5\u30fc\u30c8\u30ea\u30a2\u30eb","React","TypeScript"],"title":"React Tutorial\u3092 TypeScript\u3068Hooks\u3067\u66f8\u304d\u76f4\u3057\u3066\u307f\u305f\u2463","provider_name":"Hatena Blog","blog_title":"rikuto tech blog","image_url":null,"height":"190","provider_url":"https://hatena.blog","version":"1.0","author_name":"riku929hr","blog_url":"https://blog.riku929hr.com/"}