Vue - 解決路由過渡動畫抖動問題

来源:https://www.cnblogs.com/chanwahfung/archive/2020/01/03/12147346.html
-Advertisement-
Play Games

前言 作為 的核心模塊,它為我們提供了基於組件的路由配置、路由參數等功能,讓單頁面應用變得更易於管理。良好的路由管理尤為重要,比如路由攔截、路由懶載入、路由許可權等都在開發中起著至關重要的作用。同時路由還支持視圖過渡效果,沒有添加過渡動畫的路由切換會感覺很生硬,為了提高用戶體驗,路由過渡還是很有必要的 ...


前言

Vue-Router 作為 Vue 的核心模塊,它為我們提供了基於組件的路由配置、路由參數等功能,讓單頁面應用變得更易於管理。良好的路由管理尤為重要,比如路由攔截、路由懶載入、路由許可權等都在開發中起著至關重要的作用。同時路由還支持視圖過渡效果,沒有添加過渡動畫的路由切換會感覺很生硬,為了提高用戶體驗,路由過渡還是很有必要的。畢竟做出來,自己看著也舒服。
過渡動效文檔:https://cn.vuejs.org/v2/guide/transitions.html

過渡動畫抖動

代碼片段

這裡為路由添加一個淡入淡出的過渡效果

<div id="app">
  <main class="app-main">
     <Topbar />
     <transition name="fade">
        <router-view />
     </transition>
  </main>
</div>
.fade-enter,
.fade-leave-to{
  visibility: hidden;
  opacity: 0;
}
.fade-enter-active,
.fade-leave-active{
  transition: opacity .2s ease;
}
.fade-enter-to,
.fade-leave{
  visibility: visible;
  opacity: 1;
}

效果


圖中可以很明顯的看到,切換路由時,頁面會發生抖動,而且抖動的還不小,看著強迫症都犯了。
那麼問題來了,為什麼會出現這種情況?

過程

發現問題

排除代碼問題後,想到的可能是佈局問題引發的這種情況,於是在chrome的調試工具中,一邊切換路由一邊觀察佈局的變化,終於找到了一點蹊蹺

仔細觀察html的結構,會發現在路由過渡的過程中是會同時存在兩個路由,一個是即將進入的路由,一個是即將消失的路由,這時想到有沒有可能是其中一個路由占位導致抖動?

印證猜想

為了方便觀察佈局情況,將過渡的時間調大到30s,再次重覆上面的操作

在緩慢的過渡,可以更加清晰的看到,在切換到下一個路由(fade-enter-to)時,上一個路由(fade-leave-to)會占位使得下一個路由的位置下移,所以在快速過渡的情況才發生類似抖動的效果
既然問題找到了,那就找辦法來解決它!

解決問題

只需要給fade-leave-to路由添加 display:none,讓其在消失時不占位就可以解決問題。當然還可以使用定位來脫離文檔流來解決,但定位之後偏移量等都需要計算,不太推薦。

.fade-enter{
  visibility: hidden;
  opacity: 0;
}
.fade-leave-to{
  display: none;
}
.fade-enter-active,
.fade-leave-active{
  transition: opacity .2s ease;
}
.fade-enter-to,
.fade-leave{
  visibility: visible;
  opacity: 1;
}

最後效果


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • A database management system (DBMS) is system software for creating and managing databases. The DBMS provides users and programmers with a systematic ... ...
  • select count(*),t.分組欄位 from (select t.* ,to_char(t.時間,'HH24') stime,to_char(t.時間,'HH24mi') fz,to_char(時間,'d') from A twhere 時間>=to_date('2019-12-01',' ...
  • 一.字元串函數 參數character_expression:由字元數據組成的字母數字表達式,可以是常量或變數,也可以是字元列或二進位數據列 參數integer_expression:是正整數,如果 integer_expression 為負,則返回空字元串 1.SubString():截取指定的字 ...
  • 規模增長之後,性能問題無穎是非常重要的,但重要的從來不只是性能。 ...
  • 環境信息: ||源庫|目標庫| |: |: |: | |操作系統|WIN7|WIN SVR 2012 R2| |IP|x.x.x.216|x.x.x.112| |資料庫版本|10.2.0.4.0 64bi|10.2.0.4.0 64bi| |存儲方式|單實例|單實例| |ORACLE_HOME|D: ...
  • [20200103]GUID轉換GUID_BASE64.txt--//最近在做一個項目優化,裡面大量使用uuid.優缺點在鏈接:http://blog.itpub.net.x.y265/viewspace-2670513/=>[20191225]主鍵使--//用uuid優缺點.txt 有相關討論.我 ...
  • Spark相關問題 Spark比MR快的原因? 1) Spark的計算結果可以放入記憶體,支持基於記憶體的迭代,MR不支持。 2) Spark有DAG有向無環圖,可以實現pipeline的計算模式。 3) 資源調度模式:Spark粗粒度資源調度,MR是細粒度資源調度。 資源復用:Spark中的task可 ...
  • 場景 效果 註: 博客: https://blog.csdn.net/badao_liumang_qizhi 關註公眾號 霸道的程式猿 獲取編程相關電子書、教程推送與免費下載。 實現 新建Android項目,首先打開activity_main.xml 使用XML設置頁面 將其佈局改為GridLayo ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...