精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

国产精品一区免费视频| 亚洲精品中文字幕乱码| 日韩欧美一区二区在线| 亚洲三区在线观看| 亚洲女人18毛片水真多| 久久一综合视频| 久久伊人精品天天| 久久丫精品国产亚洲av不卡| 欧美一级免费| 欧美日韩免费网站| 欧美少妇一级片| 同心难改在线观看| 国产一区二区免费看| 欧美一级视频在线观看| 男人操女人的视频网站| 亚洲人和日本人hd| 欧美哺乳videos| 超碰在线播放91| 国产直播在线| 综合久久国产九一剧情麻豆| 久久综合色一本| 性一交一乱一伧老太| 日韩电影免费在线| 97国产精品免费视频| 国产男女猛烈无遮挡在线喷水| 欧美日韩夜夜| 欧美不卡在线视频| 久久久久久久高清| 国产v综合v| 婷婷六月综合网| 91网站在线观看免费| 日本中文字幕在线视频| 久久网这里都是精品| 成人精品水蜜桃| 国产深喉视频一区二区| 青青青爽久久午夜综合久久午夜| 欧美野外猛男的大粗鳮| 国产无码精品在线观看| 一区二区三区毛片免费| 国产亚洲欧洲在线| 精品人妻无码一区| 国产探花一区在线观看| 日韩av在线免播放器| 秘密基地免费观看完整版中文| 国产高清亚洲| 这里只有精品99re| 成人综合久久网| 久久久久伊人| 欧美日本不卡视频| 奇米视频888| 国产精品天堂蜜av在线播放| 欧美网站一区二区| www.99r| 78精品国产综合久久香蕉| 色综合婷婷久久| 免费黄色特级片| 精品3atv在线视频| 欧美性欧美巨大黑白大战| 少妇网站在线观看| 亚洲精品自拍| 制服.丝袜.亚洲.中文.综合| aaaaaaaa毛片| 国产精品一区二区三区美女| 亚洲高清久久网| 97伦伦午夜电影理伦片| 国产精品羞羞答答在线观看| 一区二区三区在线播放欧美| 很污很黄的网站| 午夜激情久久| 欧美日韩国产成人在线观看| 久久免费视频播放| 亚洲影视在线| 国产精品自拍偷拍视频| 国产精品国产三级国产普通话对白 | 精品久久久久久久久久久久久久久| 手机在线播放av| 九色丨蝌蚪丨成人| 亚洲欧洲国产一区| 欧美高清性xxxxhdvideosex| 少妇激情av一区二区| 日本一区二区三区dvd视频在线 | 欧美精品偷拍| 性色av一区二区咪爱| 特级做a爱片免费69| 日韩精品国产欧美| 91传媒视频在线观看| 污视频在线免费观看| 亚洲国产成人在线| 成人av在线不卡| 欧美电影网址| 欧美一区二区在线看| 中国极品少妇videossexhd| 国产影视一区| 欧美激情图片区| 日韩一级在线视频| 国产精品一级片在线观看| 久久久水蜜桃| xvideos国产在线视频| 精品国产鲁一鲁一区二区张丽 | www.久久久.com| 欧美精品一区二区不卡| 日本黄区免费视频观看| 亚洲视频一区| 国产精品一二三在线| 高清乱码毛片入口| 国产精品三级电影| 久色视频在线播放| 国产精品18| 亚洲午夜精品久久久久久久久久久久 | 亚洲成人777777| 麻豆成全视频免费观看在线看| 成人福利视频在线看| 四虎一区二区| 欧美三级午夜理伦| 久久99九九99精品| 久久久久久久有限公司| 色女人在线视频| 欧美私人免费视频| 好吊一区二区三区视频| 永久91嫩草亚洲精品人人| 国产精品激情av电影在线观看| 蜜桃视频污在线观看| 最新中文字幕一区二区三区| 成人免费视频久久| 日韩欧美天堂| 久久久亚洲成人| 亚洲免费成人网| 亚洲精品国产精华液| 最新天堂中文在线| 九九在线高清精品视频| 欧美一级高清免费播放| 免费国产黄色片| 亚洲国产成人va在线观看天堂| 日本成人xxx| 水蜜桃久久夜色精品一区| 国产不卡视频在线| 国产一二三在线观看| 色综合天天综合给合国产| 欧产日产国产精品98| 国产精品激情| 99久久精品免费看国产四区| bt在线麻豆视频| 7777精品伊人久久久大香线蕉经典版下载 | 少妇按摩一区二区三区| 亚洲美女色禁图| 激情久久av| 午夜影院在线播放| 国产手机视频精品| 天天爽夜夜爽人人爽| 国产亚洲成aⅴ人片在线观看 | 亚洲欧美另类在线观看| 国产精品久久久久久久久久久久久久久久久 | 午夜精品区一区二区三| 日韩经典一区| 永久免费看mv网站入口亚洲| 中文字幕 欧美激情| 日韩一区在线看| 欧美高清精品一区二区| 欧美日韩影院| 精品国产乱码久久久久久蜜柚| 2021中文字幕在线| 国产视频久久久久| 成人av网站在线播放| 国产精品久久毛片a| 一级网站在线观看| 精品电影一区| 免费成人深夜夜行视频| 91成人抖音| 欧美日韩国产123| 亚洲人成色777777老人头| 色婷婷综合视频在线观看| 国产精品天天干| 国产大陆精品国产| 免费在线激情视频| 日韩精品四区| 国产福利久久精品| 国产成人精品一区二三区在线观看| 爽爽爽爽爽爽爽成人免费观看| av小说天堂网| 欧美性少妇18aaaa视频| 女同久久另类69精品国产| 国产成人亚洲综合色影视| 黄www在线观看| 天天操综合网| 精品久久久久久中文字幕动漫| 桃子视频成人app| 美女国内精品自产拍在线播放| 人妻va精品va欧美va| 欧美视频日韩视频在线观看| 国产精品老熟女一区二区| 26uuuu精品一区二区| 黄色三级视频在线播放| 天堂在线亚洲视频| 日韩精品在线视频免费观看| 国产成人调教视频在线观看| 99在线热播| 成人黄色在线| 91精品国产91久久久久久吃药 | 亚洲精品456| 91久久中文字幕| 欧美三级网址| 欧美大片在线看| 成人av毛片| 亚洲国产女人aaa毛片在线| 一卡二卡在线视频| 一本到一区二区三区| 久久久国产精华液| 国产精品国产成人国产三级 | 欧美黄色录像| 91成人伦理在线电影| 久久亚洲精品人成综合网| 97在线精品国自产拍中文| 日韩av中文| 亚洲欧洲在线观看| 秋霞欧美在线观看| 日韩欧美国产一区二区三区| 最新中文字幕免费| 一本一道综合狠狠老| 日本一级一片免费视频| 亚洲精品乱码久久久久| 99国产精品无码| 国产日产欧美一区二区三区| 天堂www中文在线资源| 国产99久久久久| 中文字幕一区二区在线观看视频| 久久中文欧美| 免费成人午夜视频| 亚洲网址在线| 中文精品无码中文字幕无码专区| 久久精品国产www456c0m| 日韩视频在线观看国产| 亚洲免费毛片| 欧美极品视频一区二区三区| 欧美绝顶高潮抽搐喷水合集| 国产精品自拍首页| www国产精品| 国产伦精品一区二区三毛| 亚洲91网站| 国产精品福利视频| 大型av综合网站| 国产一区高清视频| 国语一区二区三区| 韩国一区二区三区美女美女秀| 成人搞黄视频| 精品午夜一区二区| 亚洲国产精品嫩草影院久久av| 欧美极品jizzhd欧美| 欧美精品一区二区三区精品| 日韩欧美视频一区二区三区四区 | 国产亚洲精品日韩| 久久伊伊香蕉| 中文字幕久热精品视频在线| 在线视频婷婷| 久久精品视频在线| 污污视频在线看| 91国在线精品国内播放| 日本免费久久| 国产噜噜噜噜久久久久久久久| 4438五月综合| 国产成人精品福利一区二区三区| 国产精品22p| 欧美日韩精品免费看| 欧美自拍偷拍| 欧洲金发美女大战黑人| 黄色成人av网站| 欧美黄色免费影院| 蜜臀va亚洲va欧美va天堂| 91日韩精品视频| 福利电影一区二区三区| 久久久久久久久免费看无码| 欧美激情资源网| 欧美极品视频在线观看| 日韩欧美高清视频| 91麻豆成人精品国产| 欧美成人一级视频| 国产在线视频网站| 久久成人精品视频| 蜜桃视频在线观看播放| 国产精品伦子伦免费视频| 日韩高清二区| 日本黄网免费一区二区精品| 忘忧草精品久久久久久久高清| www.好吊操| 日韩avvvv在线播放| 国产一级二级av| 26uuu精品一区二区| 中文字幕av播放| 日韩欧美亚洲成人| 国产精品高潮呻吟av| 亚洲精品国产精品自产a区红杏吧 亚洲精品国产精品乱码不99按摩 亚洲精品国产精品久久清纯直播 亚洲精品国产精品国自产在线 | 日本在线高清视频一区| 欧美96在线丨欧| 超碰网在线观看| 国产传媒日韩欧美成人| 国产在线综合视频| 亚洲国产精品嫩草影院| 中文字幕+乱码+中文乱码91| 精品国产制服丝袜高跟| www日韩tube| 97婷婷大伊香蕉精品视频| 国产精区一区二区| 日韩av在线电影观看| 精品福利电影| 在线播放免费视频| 国产日韩精品一区二区浪潮av| 免费观看一级视频| 欧美高清你懂得| 黄色在线小视频| 97视频网站入口| 国产一区二区av在线| 日本中文不卡| 一区二区三区国产盗摄| 色诱av手机版| 亚洲欧洲国产专区| 欧美三级网站在线观看| 国产视频精品一区二区三区| 欧美v亚洲v| 91成人理论电影| 亚洲成人av| 图片区乱熟图片区亚洲| 欧美激情一区二区三区全黄| 国产精品免费精品一区| 欧美精品一区二| 黑人另类精品××××性爽| 91亚洲va在线va天堂va国| 欧美成人自拍| 自拍偷拍一区二区三区四区| 久久久久久亚洲综合影院红桃| 日韩精品一卡二卡| 亚洲第一综合天堂另类专| 黄色小说在线播放| 高清一区二区三区视频| 欧美日韩国产色综合一二三四| 欧美一级免费在线| 亚洲免费视频成人| 99久久精品免费看国产交换| xxx欧美精品| 一区二区三区日本视频| 中文字幕日韩精品一区二区| 久久国产麻豆精品| 日本在线观看网址| 欧美日韩一本到| 日本在线人成| 亚洲影视中文字幕| 欧美激情日韩| 中国免费黄色片| 午夜久久久影院| 天堂中文在线看| 欧美一级高清免费| 精品福利久久久| 中日韩av在线播放| 136国产福利精品导航| 国产女人高潮毛片| 久久99亚洲热视| 国产精品高潮呻吟久久久久| 国产特级黄色大片| 国产亚洲成aⅴ人片在线观看| 中文字幕自拍偷拍| 久久精品久久久久电影| 爱情电影网av一区二区| 久久福利一区二区| 91麻豆精东视频| 中文字幕久久熟女蜜桃| 久久在线免费观看视频| www国产精品| 国产精品涩涩涩视频网站| 国产精品嫩草99a| 性欧美一区二区三区| 777777777亚洲妇女| 欧美偷拍综合| 人妻巨大乳一二三区| 亚洲福利视频三区| 国产对白叫床清晰在线播放| 国产欧美日韩精品在线观看| 欧美日韩91| 又黄又爽的网站| 在线精品观看国产| 伊人在我在线看导航| 国产在线精品一区| 另类小说一区二区三区| 久青草免费视频| 尤物yw午夜国产精品视频| 亚洲精品在线a| 免费激情视频在线观看| 亚洲免费成人av| 欧美孕妇性xxxⅹ精品hd| 91久久精品日日躁夜夜躁国产| 亚洲精品婷婷| 2014亚洲天堂| 日韩乱码在线视频| 日韩专区视频| 日日摸日日碰夜夜爽av| 亚洲欧洲综合另类| 韩国中文免费在线视频| 97中文在线| 蜜臀av一级做a爰片久久| 偷偷操不一样的久久| 久久综合网hezyo| 沈樵精品国产成av片| gogo亚洲国模私拍人体|