什麼是觀看轉場效果?(2024 年 Google I/O 大會更新內容)

發布日期:2024 年 5 月 16 日

2024 年 Google I/O 大會上,我宣布了檢視畫面轉場的後續步驟:多頁應用程式 (MPA) 的跨文件檢視畫面轉場。

除此之外,我還分享了一些改善項目,讓您更輕鬆地處理一般檢視畫面轉場效果。

  • 使用 view-transition-class 在檢視畫面轉場虛擬元素之間共用動畫樣式。
  • 使用有效類型的選取檢視畫面轉場效果。

這些改善項目適用於單頁應用程式 (SPA) 的相同文件檢視畫面轉場,以及 MPA 的跨文件檢視畫面轉場。

MPA 的跨文件檢視轉場效果

瀏覽器支援

  • Chrome:126。
  • Edge:126。
  • Firefox:不支援。
  • Safari 技術預覽:支援。

在 Chrome 111 中,Chrome 團隊推出了單頁應用程式相同文件檢視畫面轉場效果,這項功能在網頁建構社群中大受歡迎。

很高興看到許多人使用檢視畫面轉場效果建構內容。從「讓縮圖變成大相片」的常見實作,到 Airbnb 這類高度客製化沉浸式體驗,真厲害!

與 Airbnb 相同的文件檢視畫面轉場效果。

不過,初始實作方式要求您建構 SPA,才能使用檢視畫面轉場效果。從 Chrome 126 開始,系統現在會預設為同源導覽啟用檢視畫面轉場效果。您現在可以在同源的兩份不同文件之間建立檢視畫面轉場效果。

如要啟用跨文件檢視畫面轉場效果,兩端都必須選擇加入。如要這麼做,請使用 @view-transition at-rule,並將 navigation 描述元設為 auto

@view-transition {
  navigation: auto;
}

跨文件檢視畫面轉場會使用與同文件檢視畫面轉場相同的構件和原則。系統會擷取已套用 view-transition-name 的元素,您可以使用 CSS 動畫自訂動畫。

如要自訂跨文件檢視畫面轉場效果,請使用 pageswappagereveal 事件,這樣您就能存取檢視畫面轉場效果物件。

  • 有了 pageswap,您可以在舊快照擷取前,在即將離開的網頁上進行一些最後一刻的變更。
  • 使用 pagereveal 時,您可以在新頁面初始化後開始轉譯前,先自訂新頁面。

在兩個事件中,您都可以存取 NavigationActivation 物件,根據舊和新目的地記錄項目或導覽類型自訂跨文件檢視畫面轉場效果

為了進一步提升效能,您可以使用轉譯阻斷功能等待內容載入,並依賴預先轉譯,以縮短檢視畫面轉場執行前的載入時間。

示範

這個 Stack Navigator 示範結合了所有這些功能 (以及一些改善)。

Stack Navigator 示範的錄影。它會使用跨文件檢視畫面轉場效果,這些轉場效果是在 pagereveal 事件中根據導覽啟用資訊自訂。並使用預先算繪功能。

這是在相同來源上代管跨文件導覽的 MPA。使用 pagereveal 時,系統會根據舊版和新版目的地記錄項目決定動畫類型。

window.addEventListener("pagereveal", async (e) => {
  if (e.viewTransition) {
    // Determine animation type based on the old/new history entries
    const transitionClass = determineTransitionClass(navigation.activation.from, navigation.currentEntry);
    document.documentElement.dataset.transition = transitionClass;

    // Cleanup after transition ran
    await e.viewTransition.finished;
    delete document.documentElement.dataset.transition;
  }
});

閱讀說明文件

如要進一步瞭解如何啟用及自訂跨文件檢視畫面轉場效果,請參閱跨文件檢視畫面轉場效果說明文件


改善檢視轉場效果

除了為 MPA 提供跨文件檢視畫面轉場效果外,Chrome 也針對一般檢視畫面轉場效果進行了一些精進。

這些改善項目適用於 SPA 的相同文件檢視畫面轉場,以及 MPA 的跨文件檢視畫面轉場。

使用 view-transition-class 共用動畫樣式

瀏覽器支援

  • Chrome:125。
  • Edge:125。
  • Firefox:不支援。
  • Safari:18.2。

在此之前,如果要以相同方式為多個快照製作動畫,就必須針對每個具有專屬 view-transition-name 的元素重複其擬似選取器,個別指定每個快照。

有了 view-transition-class,您現在可以為所有快照新增共用名稱。在偽造選取器中使用這個共用名稱,即可指定所有符合條件的快照。這會產生更簡單的選取器,可自動從一個元素擴展至多個元素。

#cards-wrapper > div {
  view-transition-class: card;
}
html::view-transition-group(.card) {
  animation-timing-function: var(--bounce);
}

以下卡片範例使用 view-transition-class,透過單一選取器將相同的動畫時間設定套用至多個快照。

卡片示範錄影。使用 view-transition-class 時,系統會將相同的 animation-timing-function 套用至所有卡片 (除了新增或移除的卡片)。

如要進一步瞭解 view-transition-class,請參閱 view-transition-class 專屬說明文件

使用有效類型的選取檢視畫面轉場

瀏覽器支援

  • Chrome:125。
  • Edge:125。
  • Firefox:不支援。
  • Safari:18 歲。

在擷取及執行檢視畫面轉場時,我們也新增了可在檢視畫面轉場中加入類型的功能,以便進一步改善檢視畫面轉場。這樣一來,您就能在同一個網頁上使用各種檢視畫面轉場效果,而不會因為宣告而影響其他畫面。

舉例來說,當您在分頁序列中前往下一頁或上一頁時,您可能會根據要前往序列中較高或較低的頁面,使用不同的動畫。

分頁示範的錄製影片。類型會決定要使用的動畫。有效的轉場類型會在樣式表單中分隔樣式。

在活動類型推出之前,您可以將類別新增至 DOM,並在 CSS 中回應這些類別。不過,您也必須在轉換完成後進行清理。

使用檢視畫面轉場類型,您可以獲得相同的結果,而且這些類型在檢視畫面轉場完成後會自動清除,只有在擷取或執行轉場時,系統才會套用類型。

針對同一個文件的檢視畫面轉場效果,請將 types 傳遞至現在接受物件的 startViewTransition 方法update 是更新 DOM 的回呼函式,而 types 是字串序列。

const direction = determineBackwardsOrForwards();

const t = document.startViewTransition({
  update: updateTheDOMSomehow,
  types: ['slide', direction],
}););

如要進行跨文件檢視轉場,請使用 types 描述元標記,在 @view-transition at-rule 中設定類型,或是在 pageswappagereveal 事件中即時設定類型。

@view-transition {
  navigation: auto;
  types: slide, forwards;
}

設定類型後,您就可以使用適用於檢視畫面轉場根目錄的 :active-view-transition-type():active-view-transition 擬似類別選取器,在 CSS 中回應這些類型。

/* Animation styles for forwards type only */
html:active-view-transition-type(forwards) {
  &::view-transition-old(content) {
    animation-name: slide-out-to-left;
  }
  &::view-transition-new(content) {
    animation-name: slide-in-from-right;
  }
}

如要進一步瞭解檢視畫面轉場類型,請參閱同一個文件的檢視畫面轉場跨文件檢視畫面轉場的專屬說明文件。


意見回饋

我們非常重視開發人員的意見回饋。如要這樣做,請在 GitHub 上向 CSS 工作小組回報問題,並提供建議和問題。在問題名稱前方加上 [css-view-transitions]

如果遇到錯誤,請改為回報 Chromium 錯誤