<router-link>
<router-link>
는 라우터 지원 앱에서 사용자 네비게이션을 가능하게하는 컴포넌트입니다. 목표 위치는 to
prop로 지정됩니다. 기본적으로 올바른 href
를 갖는 <a>
태그로 렌더링 되지만 tag
prop로 구성 될 수 있습니다. 또한 대상 라우트가 활성화되어 있으면 링크가 자동으로 active CSS 클래스를 가져옵니다.
<router-link>
는 다음과 같은 이유로 하드 코드 된 <a href="...">
보다 선호됩니다.
HTML5 히스토리 모드와 해시 모드에서 모두 동일한 방식으로 작동하므로 모드를 전환하기로 결정하거나 라우터가 IE9에서 해시 모드로 전환 한 경우 변경할 필요가 없습니다.
HTML5 히스토리 모드에서,
router-link
는 클릭 이벤트를 차단하여 브라우저가 페이지를 다시 로드하지 않도록합니다.HTML5 히스토리 모드에서
base
옵션을 사용할 때to
prop의 URL에 이를 포함 할 필요가 없습니다.
Props
to
자료형:
string | Location
필수
링크의 대상 라우트를 나타냅니다. 클릭하면,
to
prop의 값은 내부적으로router.push()
에 전달 될 것이므로 값은 문자열이나 위치 디스크립터 객체가 될 수 있습니다.<!-- 리터럴 string --> <router-link to="home">Home</router-link> <!-- 이렇게 렌더링 됩니다. --> <a href="home">Home</a> <!-- `v-bind`를 이용한 표현식 --> <router-link v-bind:to="'home'">Home</router-link> <!-- `v-bind`를 생략하면 다른 prop를 바인딩 하는 것과 같습니다. --> <router-link :to="'home'">Home</router-link> <!-- 위와 같습니다. --> <router-link :to="{ path: 'home' }">Home</router-link> <!-- 이름을 가지는 라우트 --> <router-link :to="{ name: 'user', params: { userId: 123 }}">User</router-link> <!-- 쿼리가 있으면, `/register?plan=private` 이 됩니다. --> <router-link :to="{ path: 'register', query: { plan: 'private' }}">Register</router-link>
replace
자료형:
boolean
기본값:
false
replace
prop를 설정하면 클릭할 때router.push()
대신router.replace()
를 호출할 것이므로 내비게이션은 히스토리 레코드를 남기지 않을 것입니다.<router-link :to="{ path: '/abc'}" replace></router-link>
append
자료형:
boolean
기본값:
false
append
prop를 설정하면 항상 상대 경로가 현재 경로에 추가됩니다. 예를 들어/a
에서 상대 링크b
로 이동한다고 가정하면append
없이/b
에서 끝나지만append
로/a/b
에서 끝납니다 .<router-link :to="{ path: 'relative/path'}" append></router-link>
tag
자료형:
string
기본값:
"a"
때때로 우리는
<router-link>
를<li>
과 같은 다른 태그로 렌더링되길 바랍니다. 그런 다음tag
prop를 사용하여 렌더링할 태그를 지정할 수 있으며 탐색을 위해 클릭 이벤트를 계속 수신합니다.<router-link to="/foo" tag="li">foo</router-link> <!-- 이렇게 렌더링됩니다 --> <li>foo</li>
active-class
자료형:
string
기본값:
"router-link-active"
링크가 활성화 되어 있을 때 적용된 active CSS 클래스를 구성합니다. 기본값은
linkActiveClass
라우터 생성자 옵션을 통해 전역적으로 설정될 수 있습니다.exact
자료형:
boolean
기본값:
false
기본 활성 클래스 매치 동작은 포괄적인 매칭 입니다. 예를 들어,
<router-link to="/a">
는 현재 경로가/a
또는/a/
로 시작하는 한 이 클래스를 적용합니다.이것의 결과는
<router-link to="/">
가 모든 라우터에 대해 활성화 될 것입니다! 링크를 "완전 일치 모드"로 강제하려면exact
prop를 사용하십시오.<!-- 이 링크는 `/` 에서만 active 됩니다 --> <router-link to="/" exact>
active 링크 클래스를 설명하는 추가 예제를 확인 하십시오.
event
2.1.0+
자료형:
string | Array<string>
기본값:
'click'
링크 네비게이션을 트리거 할 수있는 이벤트를 지정합니다.
exact-active-class
2.5.0+
- 자료형:
string
- 기본값:
"router-link-exact-active"
정확하게 일치하는 링크가 활성된 상태일 때 적용되는 CSS 클래스를 지정합니다. 기본값은
linkExactActiveClass
라우터 생성자 옵션을 통해 전역으로 설정 될 수 있습니다.- 자료형:
외부 엘리먼트에 active 클래스 적용하기
때로 우리는 active 클래스가 <a>
태그 자체가 아닌 외부 엘리먼트에 적용되는 것을 원할 수 있습니다. 이 경우 <router-link>
를 사용하여 외부 엘리먼트를 렌더링하고 원시 <a>
는 내부에 작성합니다.
<router-link tag="li" to="/foo">
<a>/foo</a>
</router-link>
이 경우 <a>
는 실제 링크가 될 것이고(올바른 href
를 얻습니다.), 활성 클래스는 바깥 쪽 <li>
에 적용됩니다.