精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

瀏覽器要原生實現React的并發更新了?

開發 前端
并發更新的兩個核心API —— useTransition和useDeferredValue,都是針對「視圖切換」的場景。而在前端交互中,最主要的「視圖切換」場景就是「路由切換」,所以包含路由功能的前端框架就會集成這兩個API。而現在,一個試驗性瀏覽器API —— View Transitions API將原生實現「視圖切換」功能。

大家好,我卡頌。

要說React有什么其他框架沒有的、獨一無二的特性,那一定是「并發更新」。圍繞并發更新,存在兩個很有意思的現象:

  • 很多開發者聽說過他
  • 很少開發者直接使用過他

這兩個現象看似矛盾,其實很好解釋 —— React18之后的新特性,主要是面向上層框架的(主要是Next.js)。

換句話說,這些新特性(比如并發更新)主要是供框架集成,而不是開發者直接使用。

比如,并發更新的兩個核心API —— useTransition和useDeferredValue,都是針對「視圖切換」的場景。

而在前端交互中,最主要的「視圖切換」場景就是「路由切換」,所以包含路由功能的前端框架就會集成這兩個API。

而現在,一個試驗性瀏覽器API —— View Transitions API將原生實現「視圖切換」功能。

他到底有什么用?如果其他框架使用它,是不是能獲得React同樣的并發更新能力?

什么是視圖切換?

不管是View Transitions API,還是React的useTransition,都是為了提高「視圖切換」場景下的用戶體驗。

什么是「視圖切換」?以view-transitions Demo[1]舉例。這是個簡單的相冊Demo,點擊左邊圖片縮略圖,右邊會顯示大圖:

整個過程簡單來說包括3個步驟:

  • 點擊縮略圖。
  • 請求大圖數據。
  • 大圖請求成功后,顯示大圖。

從步驟1到3的過程就是個典型的「視圖切換」。整個過程有很多可以優化體驗的地方,比如:

  • 從舊圖到新圖的漸變過渡效果。
  • 點擊縮略圖發起圖片請求后,大圖區域可以先顯示舊圖(而不是立刻顯示loading效果),待新圖請求成功后再過渡到新圖。

這里解釋下第二點,對于切換類的交互,相比于「當視圖切換時立刻顯示loading效果,待新視圖加載完成后過渡到新視圖」,「當視圖切換時先顯示舊視圖,待新視圖加載完成后過渡到視圖」在延遲不高的情況下體驗會更好。

除了上述這些「體驗優化的點」,視圖切換的實現還有很多細節需要考慮,比如:

  • 如何處理新舊視圖切換時的過渡效果?
  • 如何處理新視圖加載時的loading效果?
  • 當正在請求新視圖數據時(此時視圖處在舊視圖中),用戶又對舊視圖產生交互怎么辦?
  • 視圖切換時如何處理頁面滾動位置、光標聚焦(focus)位置?
  • 對于使用屏幕閱讀器的盲人,視圖切換時閱讀器會朗讀什么?

除此之外,不同場景下的「視圖切換」實現細節也不同。比如,如何在切換頁面時優化視圖切換效果?

在SPA(單頁應用)出現之前,網站通常是由多個頁面組成。比如下面網站的每個Tab欄,對應一個獨立網頁,其中:

  • bramus Tab對應 https://http203-playlist.netlify.app/with-bramus/
  • cassie Tab對應https://http203-playlist.netlify.app/with-cassie/

在Tab之間切換,瀏覽器會:

  • 卸載之前的頁面
  • 請求新頁面數據
  • 加載新頁面

從「頁面卸載」到「頁面加載」之間的白屏間隙會造成屏幕閃爍。

要優化這種場景下優化視圖切換效果,當前唯一做法是利用history API接管路由操作,將網頁變成一個SPA。

既然「視圖切換」是如此常見的需求,且有這么多需要考慮的因素,那瀏覽器為什么不原生實現呢?

于是,View Transitions API應運而生。

當前View Transitions API不支持跨頁面的視圖切換,但未來會支持。

View Transitions的使用

View Transitions API[2]的使用很簡單,只需要用document.startViewTransition包裹視圖切換后的回調函數即可。

對于上述相冊示例,回調函數的邏輯是「將img標簽src屬性更新為新圖片地址」

const transition = document.startViewTransition(() => {
  galleryImg.src = /* 新圖片地址 */;
});

剩下所有跟過渡相關的實現,都由Transitions API解決。

View Transitions實現原理

在視圖切換時,存在2個概念:

  • 切換前的舊視圖
  • 切換后的新視圖

當使用View Transitions后,會依次做:

  • 對頁面進行截圖,作為舊視圖。
  • 執行傳遞給document.startViewTransition的回調。
  • DOM更新后,對更新后的頁面進行截圖,作為新視圖。

構造一棵代表過渡效果的偽元素樹,掛載在根元素(html元素)下,結構類似如下:

::view-transition
└─ ::view-transition-group(root)
   └─ ::view-transition-image-pair(root)
      ├─ ::view-transition-old(root)
      └─ ::view-transition-new(root)

其中:

  • 舊視圖保存在::view-transition-old(root)中。
  • 新視圖保存在::view-transition-new(root)中。

對于上述相冊示例,掛載的偽元素樹結構如下:

之所以要掛載一棵偽元素樹,主要是因為兩個原因:

  • 開發者可以對微元素應用CSS規則。

比如,上述兩個「保存了新/舊視圖的截圖」的偽元素,類似于img標簽,開發者可以對他們應用CSS動畫,當新/舊視圖切換時,實現自定義的過渡效果。

  • 方便對整個頁面中不同「視圖切換」分組。

比如,在上述相冊示例中,視圖切換的元素包括兩部分:

  • 新/舊視圖之間的切換(下圖紅框部分)
  • 新/舊圖片名稱的切換(下圖綠框部分)

相冊對應的HTML結構如下:

  • img標簽對應視圖部分(下圖紅框部分)。
  • figcaption標簽對應圖片名稱部分(下圖綠框部分)。

當我們為figcaption元素設置不同的view-transition-name:

figcaption {
  view-transition-name: figure-caption;
}

會得到一棵新的偽元素樹,其中「視圖部分」和「圖片名稱部分」偽元素是分離開的:

通過給頁面中不同HTML元素定義不同的view-transition-name屬性,就能獨立控制這個元素是視圖切換時的過渡效果。

與 React 的區別

瀏覽器原生的View Transitions API與React中的useTransition相比,誰更強大呢?

毫無疑問,前者更強大。

這是因為,對于View Transitions API,通過操作偽元素樹,開發者可以自定義過渡效果(就像對img元素使用CSS過渡動畫一樣簡單)。即使不使用CSS Transition,使用JS Transition也完全沒問題。

document.startViewTransition方法會返回一個transition對象實例:

const transition = document.startViewTransition(() => {
  galleryImg.src = /* 新圖片地址 */;
});

該實例包含了一系列視圖切換生命周期對應的promise,比如:

  • ViewTransition.ready:偽元素樹構造完成,準備開始過渡時。
  • ViewTransition.finished:過渡效果完成后,此時新視圖已經可以響應用戶交互。

而在React中,使用useTransition后,與其說完成的是「視圖切換」,不如說完成的是:

  • 首先,完成狀態的切換。
  • React內部再將狀態變化映射到視圖變化。

本質來說,操作視圖的是React,而不是開發者。所以,開發者很難控制過渡效果。

動效庫Framer的作者認為,由于開發者很難控制并發更新的完整生命周期,所以很難在并發更新時表達animation效果:

簡單來說就是,開發者很難為并發更新定制過渡效果(用CSS或JS)。

總結

可以認為,View Transitions API是比useTransition抽象程度更高、開發者可控性更高的API。useTransition能實現的,他可以。useTransition不能實現的,他也可以。

要說缺點,View Transitions API是Web平臺獨有的,而useTransition依賴React核心的并發更新能力,是跨端的。

當前,View Transitions API的兼容性并不好:

但是,一旦他變成可以大規模使用的API,那么其他前端框架只要接入他,就能輕松獲得比React耗費大量精力實現的useTransition(以及底層的并發更新特性)更強大的視圖切換能力。

參考資料

[1]view-transitions Demo:https://mdn.github.io/dom-examples/view-transitions/#。

[2]View Transitions API:https://developer.mozilla.org/en-US/docs/Web/API/View_Transitions_API。

責任編輯:姜華 來源: 魔術師卡頌
相關推薦

2021-09-28 05:51:25

PostTaskReact瀏覽器

2024-02-02 12:52:34

瀏覽器時間切片線程

2015-01-21 15:45:50

斯巴達瀏覽器

2009-12-31 17:02:40

Ubuntu Fire

2021-08-28 06:15:49

瀏覽器手機瀏覽器夸克

2014-06-24 15:43:56

Opera瀏覽器

2009-03-22 10:08:25

SilverLight瀏覽器

2023-10-26 08:59:42

2010-04-05 21:57:14

Netscape瀏覽器

2012-06-07 13:47:34

Chrome瀏覽器Android

2020-10-19 10:25:57

ReactReact.js前端

2010-12-15 11:30:33

Mozilla瀏覽器

2020-12-17 11:08:20

Safari手機瀏覽器蘋果

2012-03-20 11:31:58

移動瀏覽器

2012-03-20 11:41:18

海豚瀏覽器

2012-03-19 17:25:22

2012-03-20 11:07:08

2024-06-04 00:00:01

微軟EdgeReact

2023-09-05 09:40:55

SCSS預處理器

2023-09-05 09:44:26

CSS處理器函數
點贊
收藏

51CTO技術棧公眾號

国产aⅴ爽av久久久久成人| 四虎免费在线观看视频| 亚洲另类欧美日韩| 国产麻豆一区二区三区精品视频| 色网综合在线观看| 亚洲免费视频一区| 国产成人手机在线| 国产老妇伦国产熟女老妇视频| h片在线免费观看| 成人avav影音| 欧美一区一区| 国产剧情在线观看一区二区| 国外成人在线视频| 69精品无码成人久久久久久| 国产精品一区免费在线| 欧美丝袜美女中出在线| 在线观看一区二区三区三州| 手机看片一区二区三区| 久久成人精品无人区| 69视频在线免费观看| 手机av在线看| 国产麻豆精品久久| 亚洲第一区中文99精品| 国产一伦一伦一伦| 欧美日韩在线观看首页| ...中文天堂在线一区| 久久久一本精品99久久精品| www.桃色av嫩草.com| 日日噜噜夜夜狠狠视频欧美人 | 日韩免费精品视频| 精品97人妻无码中文永久在线| 欧美日韩伦理| 亚洲欧美日韩国产中文专区| 日本一级大毛片a一| 色噜噜成人av在线| 91国产福利在线| 欧美亚洲国产成人| 91桃色在线| 一区二区三区 在线观看视频| 亚洲永久激情精品| 特级西西444www大精品视频| 欧美性x x x| 成人在线丰满少妇av| 日韩精品免费在线播放| 黄色激情在线观看| 一区二区三区免费在线看| 欧美日韩精品久久久| 亚洲精品高清无码视频| 亚洲综合电影| 成人看片网页| 国产精品久久久久久| 日韩精品极品视频免费观看| 中文字幕制服丝袜| 日韩成人视屏| 日韩一级黄色大片| 伊人五月天婷婷| 亚洲一区二区小说| 欧美日韩aaaaa| 亚洲视频一二三四| 91成人精品观看| 91精品国产欧美日韩| 污污网站免费观看| 日韩在线电影| 日韩美女一区二区三区四区| 少妇熟女视频一区二区三区| 草草视频在线一区二区| 欧美精品一区二区精品网| 国产51自产区| 香蕉久久夜色精品国产更新时间| 亚洲精品网站在线播放gif| 在线免费观看黄色小视频| 奇米狠狠一区二区三区| 一本久久综合亚洲鲁鲁| 日本一级特级毛片视频| 欧美精品99| 日韩免费观看高清完整版| 国产丝袜高跟一区| 久久久久久久片| 欧美精品一区二区蜜桃| 丁香婷婷成人| 精品伊人久久97| 青青精品视频播放| 国产精品91av| 久久久久久毛片免费看 | 黄色一级大片在线观看| 欧美日韩在线观看成人| 国产精品chinese在线观看| 亚洲高清av在线| 人人人妻人人澡人人爽欧美一区| 99精品在线免费在线观看| 欧美黄色片免费观看| www.国产高清| 久久99国产精品久久| 国产精品毛片va一区二区三区| 亚洲人午夜射精精品日韩| 国产精品毛片高清在线完整版| 亚洲欧洲精品一区二区| h片视频在线观看| 在线一区二区三区做爰视频网站| 色一情一区二区三区| 久久香蕉精品香蕉| 日韩中文字幕在线| 国产成人无码精品亚洲| 久久99精品国产麻豆婷婷| 九9re精品视频在线观看re6| 日韩欧美小视频| 欧美性xxxx18| 又黄又爽又色的视频| 超碰在线人人干| 母乳一区在线观看| 91视频-88av| 久久久久久青草| 天天天综合网| 天天影视涩香欲综合网| 少妇一级淫免费播放| av动漫精品一区二区| 中文字幕av一区中文字幕天堂 | 999国内精品视频在线| 国产精品一区二区婷婷| 午夜欧美大尺度福利影院在线看 | 国产高清视频一区二区| 亚洲欧洲黄色网| 韩国av免费观看| 国产成人精品免费视频网站| 亚洲区一区二区三区| 涩涩视频在线| 精品国产人成亚洲区| 2025国产精品自拍| 蜜桃久久久久久| 日韩久久不卡| 影视一区二区三区| 日韩精品免费电影| 日本一级黄色录像| 成人在线视频首页| 欧美美女黄色网| 99综合久久| www日韩欧美| 在线免费一级片| 精品视频在线你懂得| 久久综合一区二区| ijzzijzzij亚洲大全| 久久精品日产第一区二区三区| 亚洲天堂视频在线播放| 久久日韩精品一区二区五区| 成人一对一视频| 视频在线观看免费影院欧美meiju| 日韩色性视频| 欧美日韩国产在线看| 免费黄色a级片| 欧美成人亚洲| 99国产在线观看| 国内精品久久久久久野外| 欧美男人的天堂一二区| 免费黄色在线网址| 麻豆成人综合网| 亚洲国产精品一区二区第一页| 污网站免费在线| 二区三区不卡| 国产午夜一区二区| 姑娘第5集在线观看免费好剧| 国产亲近乱来精品视频| 五月婷婷激情久久| 国产精品久久久久久久久久10秀| 成人在线一区二区| 色呦呦网站在线观看| 欧美不卡视频一区| 日韩美女视频网站| 久久综合九色综合欧美就去吻 | 最新国产乱人伦偷精品免费网站| 国产另类自拍| 人妻一区二区视频| 成人直播大秀| 91久久精品美女| 国内高清免费在线视频| 亚洲精品中文字| 在线观看国产小视频| 亚洲男人天堂av| 中文字幕免费高清视频| 久久最新视频| 中文字幕久久一区| av不卡一区| 国产精品美女午夜av| 91麻豆免费在线视频| 亚洲精品97久久| 亚洲天堂中文网| 亚洲国产wwwccc36天堂| 一级片视频免费看| 国产精品一区二区久久精品爱涩| 999在线观看视频| 日本一区二区免费高清| 91中文字幕一区| 亚洲黄色网址| 欧美猛交免费看| 成人午夜电影在线观看| 日韩欧美色综合| 精品国产乱子伦| 亚洲在线视频免费观看| 免费看91的网站| 成人小视频免费在线观看| youjizzxxxx18| 亚洲经典在线看| 一区二区三区一级片| 日韩av系列| 18成人在线| 成人全视频免费观看在线看| 6080yy精品一区二区三区| 日本在线免费| 亚洲三级 欧美三级| 亚洲av无码乱码国产精品| 欧美午夜影院一区| 国产精品一国产精品最新章节| 高清毛片aaaaaaaaa片| 在线亚洲免费视频| 日本高清www免费视频| 亚洲日本中文字幕区| av电影网站在线观看| 成人午夜电影久久影院| 99九九99九九九99九他书对| 米奇777在线欧美播放| 久久精品xxx| 亚洲一区二区| 亚洲一卡二卡区| 国产精品免费99久久久| 久久视频在线观看中文字幕| 伊人精品综合| 99视频免费观看蜜桃视频| 亚洲最大的免费视频网站| 热re99久久精品国产66热| 97人人在线视频| 欧美黄色免费网站| 91高清在线观看视频| 日韩中文字幕视频在线| 国产在线视频福利| 亚洲人成伊人成综合网久久久 | 日韩av在线免费观看一区| 精品久久无码中文字幕| 91精品国产综合久久香蕉麻豆| 这里只有精品免费视频| 色婷婷av一区二区三区软件| 成人免费a视频| 精品久久久一区| 国产原创视频在线| 精品动漫一区二区| 日韩av片在线播放| 无码av免费一区二区三区试看| 国产真实乱人偷精品视频| 亚洲伊人伊色伊影伊综合网| 强行糟蹋人妻hd中文| 亚洲在线观看免费| 精品视频在线观看免费| 亚洲成人一区二区在线观看| 日本亚洲色大成网站www久久| 午夜在线成人av| 日韩精品乱码久久久久久| 香蕉av福利精品导航| 综合激情网五月| 一本色道亚洲精品aⅴ| 成人免费视频国产免费| 欧美性一二三区| 91国产精品一区| 日韩三级免费观看| 日韩一级片免费在线观看| 国产一区不卡视频| 成人短视频在线看| 中文字幕一区二区三区欧美日韩 | 精品国产一区二区亚洲人成毛片| 国产特级黄色片| 日韩免费看网站| 香蕉久久一区二区三区| 亚洲人成电影在线播放| 最新97超碰在线| 欧美精品中文字幕一区| a在线视频v视频| 国产精品吊钟奶在线| **国产精品| 国产精品美女久久久久av福利| 天堂一区二区三区四区| 亚洲国产精品久久久久婷婷老年| 你懂的一区二区| 欧美日韩一道本| 免费观看在线综合| 久久久久中文字幕亚洲精品 | 国产精品186在线观看在线播放| 国语自产偷拍精品视频偷| 北岛玲heyzo一区二区| 国产一区二区丝袜| 风间由美性色一区二区三区四区 | 久久国产精品色| 日韩一级片网站| 亚洲一区二区免费视频软件合集| 九九热在线免费观看| 国产一区二区三区免费在线 | 538视频在线| 欧洲中文字幕国产精品| 高清一区二区中文字幕| 精品视频一区二区三区四区| 四虎成人av| 久久成人免费观看| 久久99国产精品久久99| 中国黄色a级片| 亚洲蜜臀av乱码久久精品蜜桃| 国产精品视频123| 日韩欧美成人一区| 国产youjizz在线| 久久免费视频在线| 色诱色偷偷久久综合| 久久精品一区二区三区不卡牛牛| 亚洲黄色av网址| 99精品黄色片免费大全| 97在线观看视频免费| 欧美性猛交xxxxx水多| av免费在线不卡| 在线观看91久久久久久| 绿色成人影院| 97se亚洲综合在线| 久久中文亚洲字幕| 日本精品一区二区三区四区| 福利视频网站一区二区三区| 色偷偷男人天堂| 色系网站成人免费| 污污网站在线免费观看| 欧美日韩国产成人高清视频| 国产精品第一| 日本一区二区高清视频| 亚洲在线免费| 久久人妻少妇嫩草av无码专区 | 欧美日韩人妻精品一区二区三区| 欧美三级韩国三级日本一级| 日本韩国一区| 91精品国产乱码久久久久久久久 | 亚洲国产三级网| 色呦呦呦在线观看| 97超碰人人看人人| 91超碰国产精品| 欧美自拍大量在线观看| 久久这里只有精品国产| 精品国产乱码久久久久久虫虫漫画| av男人天堂网| 久久99精品视频一区97| 精品国产欧美| 中国黄色录像片| 国产一区在线观看麻豆| 精品亚洲乱码一区二区| 欧美精选一区二区| 欧美尤物美女在线| 成人福利视频在线观看| 国产精品99一区二区三区| 99re6在线观看| 亚洲欧美激情一区二区| 国产高潮在线观看| 欧美激情一二区| 久久99国产精品久久99大师 | 日韩欧美成人一区二区| 欧美激情成人动漫| 国产嫩草一区二区三区在线观看 | 97久久精品国产| 小嫩嫩12欧美| 高清一区二区视频| 中文字幕一区免费在线观看| 99热这里只有精| 欧美国产视频一区二区| 男人的天堂久久| 色七七在线观看| 亚洲欧洲国产专区| 亚洲精品网站在线| 555www成人网| 超碰成人久久| japan高清日本乱xxxxx| 午夜不卡av在线| 国产精品久久一区二区三区不卡| 国产精品一区二区久久久| 亚洲影视一区| 成年人的黄色片| 精品视频在线免费看| av免费网站在线| 久久国产精品亚洲va麻豆| 日韩av电影天堂| 欧美精品久久久久性色| 亚洲美女精品成人在线视频| 一本在线免费视频| 日韩精品免费专区| 免费看黄色av| 欧美一区二区三区免费在线看| segui88久久综合| 日韩av电影在线观看| 狠狠色丁香婷婷综合久久片| 国产无套在线观看| 怡红院精品视频| 9l视频自拍蝌蚪9l视频成人| 蜜桃成人在线| 亚洲国产一二三区| 在线视频欧美性高潮| 综合久草视频| 狠狠97人人婷婷五月| 国产精品麻豆一区二区| 亚州av在线播放| 亚洲xxxxx性| 日韩国产精品久久久久久亚洲| 欧美日韩在线国产| 中文字幕日本精品|