亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue3+Tsx給路由加切換動畫時的踩坑及解決

 更新時間:2023年01月21日 08:47:00   作者:頭發(fā)掉完就不學了  
這篇文章主要介紹了Vue3+Tsx給路由加切換動畫時的踩坑及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

項目場景

用最新的技術(shù)棧Vue+Tsx給后臺管理系統(tǒng)路由加動畫時,語法上與模板語法有些許不同,記錄下自己的踩坑記錄

樣式文件

新建文件transition.scss,這里用的是若依框架人家寫好的樣式,寫好之后在全局引入該樣式文件

// global transition css

/* fade */
.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.28s;
}

.fade-enter,
.fade-leave-active {
  opacity: 0;
}

/* fade-transform */
.fade-transform-leave-active,
.fade-transform-enter-active {
  transition: all 0.5s;
}

.fade-transform-enter {
  opacity: 0;
  transform: translateX(-30px);
}

.fade-transform-leave-to {
  opacity: 0;
  transform: translateX(30px);
}

/* breadcrumb transition */
.breadcrumb-enter-active,
.breadcrumb-leave-active {
  transition: all 0.5s;
}

.breadcrumb-enter,
.breadcrumb-leave-active {
  opacity: 0;
  transform: translateX(20px);
}

.breadcrumb-move {
  transition: all 0.5s;
}

.breadcrumb-leave-active {
  position: absolute;
}

步驟

首先是第一步嘗試給路由加過渡動畫,代碼如下

<div style={{ flex: "1", paddingTop: "12px", height: 0 }}>
<Transition name="fade-transform" mode="out-in">
? ? <RouterView ?v-slots={{
? ? ? ? default: ({ Component: RouteComponent }: { Component: any }) => {
? ? ? ? ? ? return <RouteComponent />
? ? ? ? }
? ? }}
? ? ></RouterView>
</Transition>
</div>

這時候路由完全沒動畫并且報了一個警告

Component inside <Transition> renders non-element root node that cannot be animated.  

意思是在Transition動畫節(jié)點下只能有一個根節(jié)點,這時候再嘗試把RouteComponent外面套一層div

<div style={{ flex: "1", paddingTop: "12px", height: 0 }}>
<Transition name="fade-transform" mode="out-in">
? ? <RouterView ?v-slots={{
? ? ? ? default: ({ Component: RouteComponent }: { Component: any }) => {
? ? ? ? ? ? return <div><RouteComponent /></div>
? ? ? ? }
? ? }}
? ? ></RouterView>
</Transition>
</div>

這時候還是沒有切換動畫的,新警告來了

<router-view> can no longer be used directly inside <transition> or <keep-alive>.
Use slot props instead:
<router-view v-slot="{ Component }">
? <transition>
? ? <component :is="Component" />
? </transition>
</router-view>

意思是說router-view不能放在transition下,好的那我們換一種寫法試試

<div style={{ flex: "1", paddingTop: "12px", height: 0 }}>
? <RouterView v-slots={{
? ? ? default: ({ Component: RouteComponent }: { Component: any }) => {
? ? ? ? ? return <Transition name="fade-transform" mode="out-in">
? ? ? ? ? ? ? <div> <RouteComponent /></div>
? ? ? ? ? </Transition>
? ? ? }
? }}
? ></RouterView>
</div>

這時候就很完美,沒警告了。但是??王德發(fā)??切換動效在哪里??我陷入了沉思,官方文檔里給的示例是切換顯示隱藏的時候用v-if,也就是隱藏的時候dom節(jié)點被銷毀了,是不是我這個沒重新渲染呢??這時候給div加上一個動態(tài)的key讓它重新渲染就好了

import {useRoute } from 'vue-router';
const route = useRoute()
<div style={{ flex: "1", paddingTop: "12px", height: 0 }}>
? <RouterView v-slots={{
? ? ? default: ({ Component: RouteComponent }: { Component: any }) => {
? ? ? ? ? return <Transition name="fade-transform" mode="out-in">
? ? ? ? ? ? ? <div key={route.path}> <RouteComponent /></div>
? ? ? ? ? </Transition>
? ? ? }
? }}
? ></RouterView>
</div>

這時候就好了,雖然是可以了,但是這個any類型讓我很是不舒服,本著一定要寫代碼優(yōu)雅的原則,最后改動一下

最終代碼

<div style={{ flex: "1", paddingTop: "12px", height: 0 }}>
<RouterView v-slots={{
? ? default: ?({ Component }: { Component: VNode }) => {
? ? ? ? return <Transition name="fade-transform" mode="out-in">
? ? ? ? ? ? <div key={route.path} style={{ height: "100%" }}>
? ? ? ? ? ? ? ? {createVNode(Component)}
? ? ? ? ? ? </div>
? ? ? ? </Transition>
? ? }
}}/>
</div>

這樣看著就舒服了

總結(jié)

最后想說,TSX真香!走新技術(shù)的路上難免會遇到很多坑,但解決了真的很舒服

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue表單實例代碼

    Vue表單實例代碼

    Vue.js 是用于構(gòu)建交互式的 Web 界面的庫。這篇文章主要介紹了Vue表單實例代碼的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • 如何修改vue-treeSelect的高度

    如何修改vue-treeSelect的高度

    這篇文章主要介紹了如何修改vue-treeSelect的高度,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue2項目中如何使用clipboard復制插件

    vue2項目中如何使用clipboard復制插件

    這篇文章主要介紹了vue2項目中如何使用clipboard復制插件方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • vue實現(xiàn)目錄樹結(jié)構(gòu)

    vue實現(xiàn)目錄樹結(jié)構(gòu)

    這篇文章主要為大家詳細介紹了vue實現(xiàn)目錄樹結(jié)構(gòu),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue通過axios調(diào)用json地址數(shù)據(jù)的方法

    Vue通過axios調(diào)用json地址數(shù)據(jù)的方法

    在現(xiàn)代Web開發(fā)中,前后端分離已成為標準做法,Vue.js作為前端框架中的佼佼者,提供了豐富的API來處理數(shù)據(jù)和服務端的交互,其中一個常用的庫是axios,本文將詳細介紹如何在Vue項目中使用axios來調(diào)用JSON數(shù)據(jù),需要的朋友可以參考下
    2024-09-09
  • jenkins自動構(gòu)建發(fā)布vue項目的方法步驟

    jenkins自動構(gòu)建發(fā)布vue項目的方法步驟

    這篇文章主要介紹了jenkins自動構(gòu)建發(fā)布vue項目的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • VantUI封裝自定義Tabbar路由跳轉(zhuǎn)的實現(xiàn)

    VantUI封裝自定義Tabbar路由跳轉(zhuǎn)的實現(xiàn)

    本文主要介紹了VantUI封裝自定義Tabbar路由跳轉(zhuǎn)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • Vue的自定義事件之組件通信工具詳解

    Vue的自定義事件之組件通信工具詳解

    這篇文章主要介紹了Vue的自定義事件之組件通信工具詳解,Vue的自定義事件(Custom Events)是一種強大的工具,用于實現(xiàn)組件之間的通信和數(shù)據(jù)傳遞,本文將深入探討什么是Vue的自定義事件,以及如何自定義和使用它們,需要的朋友可以參考下
    2023-10-10
  • vuejs 制作背景淡入淡出切換動畫的實例

    vuejs 制作背景淡入淡出切換動畫的實例

    今天小編就為大家分享一篇vuejs 制作背景淡入淡出切換動畫的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 詳解Vue3中偵聽器watch的使用教程

    詳解Vue3中偵聽器watch的使用教程

    學過 vue2 的小伙伴們肯定學習過偵聽器,主要是用來監(jiān)聽頁面數(shù)據(jù)或者是路由的變化,來執(zhí)行相應的操作,在 vue3里面呢,也有偵聽器的用法,功能基本一樣,本文就來為大家詳細講講
    2022-07-07

最新評論