티스토리 뷰

반응형

Error: Do not use the HTML <a> tag to navigate to /urlencode/. Use Link from 'next/link' instead. See: https://nextjs.org/docs/messages/no-html-link-for-pages

 

 

Nextjs 에서 빌드 시  발행하는 에러에 대한 해결책을 적어보고자 한다. 에러의 내용을 보면 a태그를 next/link로 변경하라는 내용으로 해석된다. 사실 link 태그로 변경하면 된다. 그러나 공식문서에 나와있는 내용을 통해 조금 더 디테일하게 정리해보고자 한다.

 

기본적으로 Nextjs에서는 Single Page app 경험을 제공한다. 따라서 단순히 HTML의 a태그를 사용하면, 페이지가 새로고침 되기 때문에 client-side route가 불가능하다. 그래서 변경해 주라고 Error를 표시하는 것이다.

 

공식문서에 따르면 아래의 두가지 방법으로 해결이 가능하다. 그리고 둘 중 하나만 해도 해결이 가능하다. 첫 번째로는 eslint값을 변경하는 것이다.

 

eslintrc.json

 

위는 nextjs에서의 기본 구조이다. .eslintrc.json 파일을 열어보면 아래와 같이 설정이 되어있다.

 

{
  "extends": "next/core-web-vitals"
}

 

이러한 구조를 아래와 같이 추가해 주자.

 

{
  "extends": "next/core-web-vitals",
  "rules": {
    "@next/next/no-html-link-for-pages": ["error", "packages/my-app/pages/"]
  }
}

 

위와 같이 규칙을 추가를 해주면된다. 추가적인 eslint 부분은 다른 글(작성 예정)에서 확인하자.

 

 

link 태그 변경

a태그를 link태그로 변경해 주면된다. 아래와 같은 a 태그가 있다고 해보자.

 

<a href="/about">About Us</a>

 

위의 a 태그를 아래의 Link를 임포트 해준다.

 

import Link from 'next/link'

 

  <Link href="/about">
    <a>About Us</a>
  </Link>

 

위와 같이 Link로 a태그를 감쏴주면 빌드 시 에러가 해결된다.

반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/05   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함