styled component 버튼 타입에러
import { ReactNode } from "react";
import { Link } from "react-router-dom";
import styled from "styled-components";
interface ButtonProps {
children?: ReactNode;
onClick: (e: any) => void;
type?: "link" | "button";
url?: string;
}
const StyledButton = styled.button<ButtonProps>`
outline: none;
border: none;
display: flex;
align-items: center;
justify-content: center;
`;
function Button({ children, onClick, type = "button", url }: ButtonProps) {
const RealButton = <StyledButton onClick={onClick}>{children}</StyledButton>;
const RealLink = (
<StyledButton onClick={() => {}}>
<Link to={url!}>{children}</Link>
</StyledButton>
);
return <div></div>;
}
export default Button;강의를 보고 진행하던중에 RealLink에서 타입오류나 가서 확인을 해보니
button onClick이 없으면 styled componenet에서 에러를 내는 것 같습니다. 링크로 쓰면 onClick이벤트를 전달해주면 안될 것 같은데 ()=>{} 이처럼 의미없는 함수를 넘겨주면 될까요
Answer 1
0
grs0412님 질문 남겨주셔서 감사합니다:)
해당 onClick을 required하게 설정을 해놔서 생기는 타입 에러인 것 같습니다.
interface ButtonProps {
children?: ReactNode;
onClick?: (e: any) => void;
type?: "link" | "button";
url?: string;
}다음과 같이 onClick 메소드를 optional하게 받아주시기 바랍니다.
다시한번 질문 남겨주셔서 감사합니다.
커서 터미널에서 클로드코드 대화창에 이미지를 cmd+v 해도 붙여넣기가 안 됩니다.
0
4
1
스타터 킷 계획 모드 결과 (프로젝트생성2 강의)
0
3
0
깃 아이콘이 다른 문제
0
7
1
opus모델이 sonnet대비 사용량이 많다고하셨는데
0
12
1
우측 클로드 로고가 안떠요
0
23
1
[2회독] plan mode / task-manager / superpowers 등등
0
25
1
[2회독]Warp 사용문의
0
21
1
강의 내용 부분이 잘못 올려진 거 같아요!
0
20
0
이전 강의에서는 /init을 토큰사용량 이슈로 '보는것'만 제안 주셨는데요..
0
19
1
스타터킷에 등록한 기술스택의 업그레이드 발생 시 방법
0
34
1
수업자료 다운로드 시 빈폴더만 나오네요
0
124
2
보일러플레이트 코드 오류
0
211
2
수업자료 오류
0
158
1
MongoDB Compass 관련 질문
0
348
1
카카오 맵 api
0
273
1
mongodb 및 mongoose 초기 세팅에서 다운로드 질문입니다
0
215
1
보일러 플레이트 다운 시 빈 폴더
0
180
1
지도가 두개가 열리는 것 같습니다
0
338
1
Node.js 버전 차이로 인한 오류 발생(추정)
0
944
2
[참고] 서버 보일러 플레이트에 axios 없네요~
0
395
1
초기 보일러플레이트 설정문제
0
530
1
serach.ts 파일 질문드립니다.
1
489
1
강의자료 소스코드 질문드립니다.
0
404
1
맵 클릭 이벤트 추가 강의와 Jotai 강의 순서에 대해 건의드립니다.
1
496
1

