본 게시글은 아래의 글을 필사하였습니다.
https://router.vuejs.org/kr/guide/essentials/navigation.html
<router-link> 를 사용하여 선언적 네비게이션용 anchor 태그를 만드는 것 외에도 라우터의 인스턴스 메소드를 사용하여 프로그래밍으로 이를 수행 할 수 있습니다.
router.push(location, onComplete?, onAbort?)
참고: Vue 인스턴스 내부에서 라우터 인스턴스에 $router 로 액세스할 수 있습니다. 그러므로 this.$router.push 를 사용할 수 있습니다.
다른 URL로 이동하려면 router.push 를 사용하십시오. 이 메소드는 새로운 항목을 히스토리 스택에 넣기 때문에 사용자가 브라우저의 뒤로 가기 버튼을 클릭하면 이전 URL로 이동하게 된다.
이것은 <router-link> 를 클릭 할 때 내부적으로 호출되는 메소드이므로 <router-link :to="..."> 를 클릭하면 router.puch(...) 를 호출하는 것과 같습니다.
선언적 방식 | 프로그래밍 방식 |
<router-link :to="..."> | router.push(...) |
전달인자는 문자열 경로 또는 로케이션 디스크립터 객체가 될 수 있습니다.
예:
// 리터럴 string
router.push('home')
// object
router.push({ path: 'home' })
// 이름을 가지는 라우트
router.push({ name: 'user', params: { userId: 123 }})
// 쿼리와 함께 사용, 결과는 /register?plan=private 입니다.
router.push({ path: 'register', query: { plan: 'private' }})
2.2.0 버전 이후로 선택적으로 router.push 또는 router.replace 에 두 번째와 세 번째 전달인자로 onComplete 와 onAbort 콜백을 제공합니다. 이 콜백은 탐색이 성공적으로 완료되거나(모든 비동기 훅이 해결된 후) 또는 중단(현재 탐색이 완료되기 전에 동일한 동일한 경로로 이동하거나 다른 경로 이동)될 때 호출됩니다.
router.replace(location)
router.push 와 같은 역할을 하지만 유일한 차이는 새로운 히스토리 항목에 추가하지 않고 탐색한다는 것입니다. 이름에서 알 수 있듯이 현재 항목을 대체합니다.
선언적 방식 | 프로그래밍 방식 |
<router-link :to="..." replace> | router.replace(...) |
router.go(n)
이 메소드는 window.histroy.go(n) 와 비슷하게 히스토리 스택에서 앞으로 또는 뒤로 이동하는 단계를 나타내는 하나의 정수를 매개 변수로 사용합니다.
예제
// 한 단계 앞으로 갑니다. history.forward()와 같습니다.
router.go(1)
// 한 단계 뒤로 갑니다. history.back()와 같습니다.
router.go(-1)
// 3단계 앞으로 갑니다.
router.go(3)
// 지정한 만큼의 기록이 없으면 자동으로 실패합니다.
router.go(-100)
router.go(100)
History 조작
router.push , router.replace 및 router.go 는
window.history.pushState , window.history.replaceState 및 window.history.go 와 상응합니다. 그 들은 window.history API를 모방합니다.
따라서 브라우저 히스토리 API에 이미 익숙하다면 vue-router를 사용하여 히스토리를 손쉽게 조작 할 수 있습니다.
vue-router 네비게이션 메소드( push , replace , go )는 모든 라우터 모드 ( history , hash 및 abstract )에서 일관되게 동작합니다.
'필사적 필사' 카테고리의 다른 글
이름을 가지는 뷰 | Vue Router (0) | 2020.04.23 |
---|---|
이름을 가지는 라우트 | Vue Router (0) | 2020.04.23 |
중첩된 라우트 | Vue Router (0) | 2020.04.23 |
Base64 인코딩이란? (0) | 2020.04.16 |
서버 사이드 렌더링(SSR:Server Side Rendering)이란 (0) | 2020.03.26 |