앵귤러, 리엑트, 뷰/뷰(Vuejs)

[Vuejs] router view 그리고 transition 적용 잘 안될 때

마샤와 곰 2023. 4. 4. 10:31

 

vuejs 3버전에서 RouterView와 Transition을 힘들게 적용하여 보았습니다.

라우터 뷰(router-view) 에서 이넘의 트랜지션(transition)을 적용하는게 생각보다 어려웠었습니다.

공식 사이트에서도 정말 간단하게 설명해서..참..

아래는 개발 환경에 사용된 package.json 파일의 일부 내용 입니다.

* 파일이름 : package.json

{
  "dependencies": {
    "vue": "^3.2.47",
    "vue-router": "^4.1.6",
    "vuex": "^4.1.0"
  },
  "devDependencies": {
    "@vitejs/plugin-vue": "^4.0.0",
    "vite": "^4.1.4"
  }
}

 

그리고 아래 코드는 공식 사이트에 설명된 router에 transition을 적용하는 방법 입니다.

* 출처 : https://router.vuejs.org/guide/advanced/transitions.html

<router-view v-slot="{ Component, route }">
  <transition name="fade">
    <component :is="Component" :key="route.path" />
  </transition>
</router-view>

 

사실 뭐 직관적이고 어렵지 않아서 복붙해서 한번 적용 해 보려고 했는데..

처음 화면은 잘 뜨지만, 이후의 페이지 전환(라우팅)은 아무런 화면이 나오지를 않았습니다.

fade 이름의 css 속성을 잘못 부여한 줄 알고 이리저리 고쳐 보았고, 다른 형식의 코드를 넣어 보았지만 트랜지션 효과가 적용이 안되거나, 아니면 빈 화면만 나오기 일수였습니다.

아니 왜 안나옴?

 

위 코드에서의 문제는 소스 코드가  "단일컴포넌트" 형식의 구조로 되어있지 않기 때문에 발생한 것 이였습니다.

#원본
<Transition> only supports a single element or component as its slot content. 
If the content is a component, the component must also have only one single root element.

#번역
<Transition>는 슬롯 콘텐츠로 단일 요소 또는 구성 요소만 지원합니다.
내용이 구성 요소인 경우 구성 요소에도 단일 루트 요소가 하나만 있어야 합니다.

* 출처 : https://vuejs.org/guide/built-ins/transition.html#the-transition-component

 

Transition | Vue.js

 

vuejs.org

 

이를 고려해서 아래처럼 수정 해 보았습니다.

트랜지션(transition) 엘리먼트에 1개의 html 엘리먼트를 추가하고 그 안에 라우팅할 컴포넌트(component)가 위치하게 코드를 변경 해 보았습니다.

* div 테그의 class는 확인용도로 주었습니다.

<router-view v-slot="{ Component, route }">
    <transition name="fade">
        <div :key="route.name" class="Im-root-element">
            <component :is="Component"></component>
        </div>
    </transition>
</router-view>

 

1개의 엘리먼트가 트랜지션 영향을 받으며, 그 아래에 컴포넌트들이 라우팅한 주소값에 따라 나오게 하였습니다.

간혹 주석테그가 있으면 안된다는 글도 있어서...주석은 코드에서 제거하였습니다.

이를 실행하면 아래처럼 라우팅 된 컴포넌트가 잘 나오는 것을 볼 수 있습니다.

후아...나옵니다...ㅠㅠ

 

vuejs 3 버전에서 router view에 transition 적용이 잘 안되는 경우 위 내용처럼 한번 적용 해 보는 것도 좋을 것 같습니다.

궁금한점 또는 틀린 부분은 언제든 알려주세요! 👻

 

반응형