Bringing page transitions to the web

Поделиться
HTML-код
  • Опубликовано: 3 фев 2025

Комментарии • 525

  • @jakearchibald
    @jakearchibald 2 года назад +765

    In case you can't tell, I'm really excited about this feature, but I want to make sure we get it right. Please ask any questions you have, and I'll answer them here. Comments are also welcome on the repo linked in the description.

    • @StuartLangridge
      @StuartLangridge 2 года назад +11

      The late, not-really-seen-by-anyone-else-as-great element allowed this sort of use (although the Page Transitions API is a lot more helpful about it than was, which mostly gave you the ability to build it yourself!), but the other thing that gave developers was access to both the before page and the after page at the same time. You could use portal.activate and pass data along with it which could be received by the next page, in essence giving a way to add arbitrary extra data to a page navigation. For an SPA you don't need this (because you're all one page), but it's hard for normal websites with more than one page, and portal helped with that. (The hacky ways to do it, like sticking things in the query string or localStorage, aren't as nice, and you can't postMessage from before to after because before and after aren't both present at the same time). Is there anything that the Page Transitions (or maybe the page navigation?) API does to help with that?
      (this stuff is super duper cool, btw.)

    • @jakearchibald
      @jakearchibald 2 года назад +21

      @@StuartLangridge isn't dead, it's just resting. No, seriously, it isn't dead, it's still being thought of for that page-in-page stuff. It was delayed by the infrastructure work needed for putting a 'top level' frame within another page, which is needed for portals but also prerender.

    • @Rachoszsky
      @Rachoszsky 2 года назад +5

      Thanks for the great video, Jake! It's not only exciting stuff, but the presentation is also very well thought out (and funny ;-)
      Can you see this in action anywhere, e.g. using Chrome Canary for Android? (Not sure if I missed something)

    • @jakearchibald
      @jakearchibald 2 года назад +3

      @@Rachoszsky yep, see the description for links! Particularly the developer guide

    • @Rachoszsky
      @Rachoszsky 2 года назад +4

      @@jakearchibald Thanks! Awesome to see this in action, one step closer to that native app feeling 👍🏼

  • @insaneviruss
    @insaneviruss 2 года назад +81

    This is gonna be big! 9:43 is when my heart was literally jumping with joy like a small kid! I've been waiting for this for years. Please make this main stream soon. This has so much potential.

    • @RamonBalthazar
      @RamonBalthazar 2 года назад

      hahahah same 100%

    • @REAZNx
      @REAZNx 2 года назад

      Have you never heard of Framer Motion before?

    • @PanosPitsi
      @PanosPitsi Год назад

      @@REAZNx you are so smart lets ship 5mb of js to the client to make a buggy mess from 2007. Also it needs react on top so it doesnt work with better frameworks like sveltekit.

    • @REAZNx
      @REAZNx Год назад

      @@PanosPitsi Framer is 4kb but ok.

  • @SpaceChicken
    @SpaceChicken 2 года назад +94

    This is amazing. Excited to be able to use it in PWAs, and get that much closer to native feel.

  • @dkennell998
    @dkennell998 2 года назад +80

    Lovely!! Been thinking a lot about page transitions recently, so the timing here is perfect. This is a great intro to the new APIs

  • @kylekashuba3219
    @kylekashuba3219 2 года назад +256

    Can't wait to use this in 4 years when Apple implements it in Safari!

    • @sillvvasensei
      @sillvvasensei 2 года назад +8

      The beauty is that you can implement the feature right away, using a fallback for browsers that don't support the feature, and then simply wait until they all support it.

    • @DanKantor
      @DanKantor 2 года назад +12

      @@sillvvasensei absolutely. But iOS users not experiencing these lovely transitions is a large chunk of your intended audience I’m sure.

    • @kylekashuba3219
      @kylekashuba3219 2 года назад

      @@sillvvasensei This is true, however I'd be worried about maintenance. Whenever we want to add or change a new transition, we would have to do it twice in different ways if we want to have similar experiences.

    • @remfur750
      @remfur750 2 года назад

      Imo at this point you aren't making a series of webpages, you're making web apps. I feel like the idea of these relatively complex applications being treated as web pages is an archaic and limiting abstraction that sort of limits what the web can be.
      This is oddly coming from someone who dislikes web apps, so I'm not just hating on web-based progress.

    • @guyunknown9123
      @guyunknown9123 2 года назад +1

      XD lmao

  • @CodingPhase
    @CodingPhase 2 года назад +1

    Finally lol it only took 10+ years but finally we here!!! This has been one of those features I've always wanted.
    1. browser transitions (check)
    2. css variables (check)
    3. nested css (on hold)

  • @PatricioHondagneuRoig
    @PatricioHondagneuRoig 2 года назад +22

    I'd love for this to be discussed with other vendors and added as a cross-browser standard.
    Great job guys, it looks amazing.

    • @zamfofex
      @zamfofex 2 года назад

      Isn’t that exactly what was done?

  • @swyxTV
    @swyxTV 2 года назад +26

    We love you Jake! You're incredible and thanks to the team for all the work on this api!

  • @james-innes
    @james-innes 2 года назад +2

    Love this guys mannerisms, feels so candid and authentic not like a scripted advert or kids TV show like some Google dev vids

  • @leeboyin945
    @leeboyin945 2 года назад +20

    Brilliant! This is one of the most exciting topics for me in I/O 2022.
    It must have taken tons of hard work to make it look as simple as a breeze.
    Thanks for making web better!

  • @ciberman
    @ciberman 2 года назад +21

    This is amazing and the API is extremely clever. Currently making animations in SPA is extremely difficult. And the cleverness of this API makes it even possible to work in traditional multi page apps and this makes me even more exited because I'm mainly a backend dev

  • @CoderOne
    @CoderOne 2 года назад +3

    I absolutely love this feature and the simplicity behind it! Looking forward to try it out

  • @nielskersic328
    @nielskersic328 2 года назад +6

    This is so exciting. Probably my biggest wish for the future of the web. I'm really happy to see all the changes since v1 last year.

  • @xlayton3342
    @xlayton3342 2 года назад +6

    This is awesome! I really hope this gets widely adopted so we can use it across browsers. That'd be a dream!

  • @ironcito1101
    @ironcito1101 2 года назад +5

    Very cool! I implemented page transitions using JavaScript and CSS and it was pretty complex. I had to pre-load the content in the background, create the layout out of view, and then do the choreography. The "zoom in" transitions as seen at 9:40 are especially tough. This is a much simpler and more elegant solution. I hope that you make it generally available soon, and that other browsers follow suit. Good work!

  • @JCake
    @JCake 2 года назад

    My absolute favourite element of all of this is a single word: Customisability. I live by this principle, and I'm glad to see I'm not alone

  • @AlexanderTrefz
    @AlexanderTrefz 2 года назад +23

    I was skeptical, as I have built most of those transitions animations myself in various Apps, which is really not fun. This looks like a well thought out and flexible API - thats awesome!

  • @BenHewart
    @BenHewart 2 года назад +1

    I have been waiting ages for page transitions for web apps at last I can't wait to get my hands on it. Thanks guys!

  • @Ali-sc6dh
    @Ali-sc6dh 2 года назад +2

    The API seems so simple and well designed ! Can't wait to start poking at it !

  • @justsaying4471
    @justsaying4471 2 года назад +318

    Wow, this is cool. I like the simplicity of the api. That’s its real strength, I believe. Any news on whether other browsers will support it as well?

    • @jakearchibald
      @jakearchibald 2 года назад +79

      We've presented parts to the CSS working group, and folks have been supportive. But we don't have a real spec yet, so it's too early to ask other browsers to commit.

    • @mathe42
      @mathe42 2 года назад +7

      Even If this only lands in Chrome I will use it!

    • @justsaying4471
      @justsaying4471 2 года назад +15

      @@mathe42 absolutely. Me too. I like how easy the fallback is, as well. However, I think it won’t be widely used until the feature is adopted in the big frameworks, Angular, Vue, Nextjs, etc. And for that the api needs to be somewhat stable and widespread.

    • @tusharsnn
      @tusharsnn 2 года назад +16

      @@justsaying4471 i think it will be adapted very quickly as animation libraries uses the same pattern already for this type of page transistion. eg framer motion.

    • @_HMCB_
      @_HMCB_ 2 года назад

      Man I love this. Until other browsers adopt it, I can see creating scenario-specific web apps for kiosks and such. Just awesome.
      Is Canary available on iPadOS?!

  • @EvoSchecter
    @EvoSchecter 2 года назад +7

    "I dont know, You could probably do something better." Now THIS is how you get people into it, An Instructor who has enough confidence to encourage the students.

  • @linkcell
    @linkcell 2 года назад +1

    Thank you. I've been a vanilla html+js+css type of person because I didn't want to add the project complexity and learning required for anything extra. When this becomes standard, it will have proved that it was worth the wait.

  • @ajaymenon0
    @ajaymenon0 2 года назад +1

    I had been waiting so long for this!!!

  • @TheNewton
    @TheNewton 2 года назад +1

    8:19 responsive fade and slide transitions are now called: The Archibald

  • @dimitardimitrov4979
    @dimitardimitrov4979 2 года назад +2

    Nice! Good job to the team!
    Also impeccable presentation Jake! :)

  • @nikilragav
    @nikilragav 2 года назад +1

    You're actually using a Joycon as a clicker? Glad to find other people doing that!

  • @ZhiYin
    @ZhiYin 2 года назад

    So extremely cool, I have no word for it. Btw the production quality of this video is through the roof

  • @RamonBalthazar
    @RamonBalthazar 2 года назад

    This is the most exciting thing I've seen coming to the web in years!!!
    Thank you and congratulations 👏👏

  • @mohamedchaabouni4477
    @mohamedchaabouni4477 2 года назад +1

    Man ! your talking skills are killing it ! just thank you for this 😁

  • @AndaxH
    @AndaxH 2 года назад +2

    This is really exciting - I love that it reuses lots of existing web building blocks and APIs so you don't need to learn much new syntax and just use existing knowledge 😍

  • @zuperxtreme
    @zuperxtreme 2 года назад +1

    Love the flexibility of tagging things with CSS, cool stuff!

  • @Marie-ElisaBIAYS
    @Marie-ElisaBIAYS Год назад +1

    So sad it's only coming now, but just as excited! Can't wait to be able to use it

  • @ViktorTy
    @ViktorTy 2 года назад +1

    Now, this is what I need in web apps. I can't wait for this to come to regular chrome!

  • @tomtucjr
    @tomtucjr 2 года назад +4

    This is SO cool. Amazing work from the whole team. Looks super easy to set up.

  • @mhombach3035
    @mhombach3035 2 года назад +1

    You guys at Google are absolute legends, wtf. Can't wait to play around with the new api ö_ö

  • @karanshah838
    @karanshah838 2 года назад +1

    Can't wait for designers to go crazy with page level animations now 🤩😍😀

  • @eliotshort9905
    @eliotshort9905 2 года назад

    This is crystal clear stuff - love the interactive examples, great work

  • @Drillan767
    @Drillan767 2 года назад +1

    9:42 Oh my gooood I dreamed of that for soooo loooong ! Finallyyyy!

  • @darvil82
    @darvil82 2 года назад +2

    I am incredibly exited for this

  • @robbiethomas3373
    @robbiethomas3373 2 года назад +2

    This guy needs to do all of Google's announcements from now on. Excellent communication.

  • @mathe42
    @mathe42 2 года назад +8

    I think it would be great to define the root element so for example you have some div in your page and a transition can be created only for the content inside. The rest of the page would be interactive while the transition runs.

    • @lazareric
      @lazareric 2 года назад +1

      That's how this ought to have been done, but they are too comfy and a bit lazy at Google, i am sorry for being negative but it's true. If it was some people engineers grinding out there, with the power they have to implement such features, they would've made it properly.

  • @kapeeshmanilal1613
    @kapeeshmanilal1613 2 года назад

    Waiting patiently for this one! Its a good time to be a developer! Thanks to you and the team for this

  • @showmealldblueprints
    @showmealldblueprints 2 года назад +3

    Really really cool! Good to see some care with transitions.

  • @_va3y
    @_va3y 2 года назад +4

    Wow, that's a really game changer for SPAs and SPA-type websites. Now let's all hope, it'll become implemented soon 🤞

    • @EduardoLima-pi7fl
      @EduardoLima-pi7fl 2 года назад +1

      Totally! I was wondering about using this API with PWA features and having the possibility to deploy to Google Store, this would make it possible to write SPAs that could become very convincing native apps!

  • @B-max.
    @B-max. 2 года назад +1

    This guy is a fantastic presenter.

  • @b_two
    @b_two 2 года назад +2

    seeing jake without surma is absolutely heartrending

  • @ChrisJohnNewton
    @ChrisJohnNewton 2 года назад +1

    Bravo for making something complex simple. Looks great!

  • @sjn_
    @sjn_ 2 года назад +1

    Wow, this is one hell of an amazing feature.

  • @megadev3727
    @megadev3727 2 года назад +1

    INSANE!! can't wait for it to roll out to the main build! Will totally give it a try ;)

  • @MCFedev
    @MCFedev 2 года назад +2

    Omg yeah, I really waited on this for a long time

  • @thundernixon
    @thundernixon 2 года назад +1

    This is fantastic! Love the thinking here and the control available in CSS. Can’t wait to embrace this in my websites!

  • @albertodeagostini6143
    @albertodeagostini6143 2 года назад

    Oh boy, I'm waiting for something like this for so long

  • @lunjie9510
    @lunjie9510 2 года назад

    It's really cool! I am excited to hear this news, what a big progress in web app experience!

  • @dk0767
    @dk0767 2 года назад +3

    Subtle transition animation greatly helps usability by providing informative visual queues, but when transition animations take too long to complete, they start to distract and create headaches.
    Human eyes will want to tack any movement. When the movement speed is above a certain threshold, our eyes will give up tracking during the the transition animation and then eventually snap on the final state of the animation when it stops. This is far better than a slow transition animation where our eyes try to track the whole animation and suffers disorientation and headaches and eye strains.
    More is not necessary better. A good UI animation should not attract attention to itself.

  • @joshuafarayola6689
    @joshuafarayola6689 2 года назад +1

    This is crazy. I'm excited about it!

  • @robinator18ps3
    @robinator18ps3 2 года назад

    This! This is exiting!
    This is exactly what is missing UX wise on the web!

  • @BrianLeRoux
    @BrianLeRoux 2 года назад +2

    This is awesome and Jake is awesome give that man a raise

    • @jakearchibald
      @jakearchibald 2 года назад +2

      Printing this and mailing it to Paul

  • @AdityaTripathi
    @AdityaTripathi 2 года назад

    I can't wait for this!

  • @zhanezar
    @zhanezar 2 года назад +1

    this is what ive wanted for so long so long

  • @rasmuslaine4153
    @rasmuslaine4153 2 года назад +1

    Oh yeah, this is great. Simple and
    yet customisable.
    Powerful tool.

  • @TDefton
    @TDefton 2 года назад +1

    Omg my jaw hit the floor. I’m so excited for this to be out of canary 😍😍😍

  • @_abdul
    @_abdul 2 года назад

    Navigation API will be brilliant. Can't wait to play with it.

  • @montebont
    @montebont 2 года назад +2

    Nice concept Jake - thanks for sharing !

  • @StellarWeb008
    @StellarWeb008 2 года назад

    One who got the idea to add this is a real god

  • @jasetify
    @jasetify 2 года назад +2

    Amazing presentation of amazing new tech. I am excited!

  • @nxte8506
    @nxte8506 2 года назад +25

    This is great. I’ve witnessed firsthand while writing react-motion-router how difficult this all is. It seems simple conceptually but when you layer desirable features on top of each other it starts falling apart and introduces weird edge cases. In my case I was animating the live DOM for each page (as I was unaware of a way to screenshot the current state) which wasn’t great. One question I have is why contain: paint?

    • @dealloc
      @dealloc 2 года назад +7

      From MDN:
      > The contain CSS property allows an author to indicate that an element and its contents are, as much as possible, independent of the rest of the document tree. This allows the browser to recalculate layout, style, paint, size, or any combination of them for a limited area of the DOM and not the entire page, leading to obvious performance benefits.
      In case of these page-transitions it tells the browser to not need to paint the transitioning elements that are offscreen. In this case, elements which transition left and right outside the screen.

    • @nxte8506
      @nxte8506 2 года назад

      @@dealloc thank you so much for the explanation.

  • @kisvegabor
    @kisvegabor 2 года назад +1

    Amazing video! It was a pleasure to listen your presentation. And great feature, of course!

  • @TinoBurset
    @TinoBurset 2 года назад +2

    This is absolutely fantastic! And, as usual, awesome presentation Jake! 🍻

  • @zshn
    @zshn 2 года назад +2

    Absolutely gorgeous! I did the screenshot thing but it will be great to have native API.

  • @stefanogagliardi4665
    @stefanogagliardi4665 2 года назад +1

    This concept of "Page transistion" reminded me of NextJs; as it has the "shared Layout" conectto which is not reloaded during navigation (eg. header and footer) and in which the pages are injected without reloading. Not having to reload allows you to apply page transitions.

  • @srsajjad7460
    @srsajjad7460 2 года назад

    This is a super demonstration of an exciting API

  • @knolljo
    @knolljo Год назад

    Very exited about this feature! Great speaker too!

  • @AbdallaElmedny
    @AbdallaElmedny 2 года назад +1

    Super cool! Look forward to standardisation of this 👌

  • @ooogabooga5111
    @ooogabooga5111 2 года назад

    beautiful , this might be the next curve on web

  • @Dominik-K
    @Dominik-K 2 года назад +1

    This is an amazing idea, and I'm looking forward to what can be achieved with this pattern

  • @bludauitservices2109
    @bludauitservices2109 2 года назад

    i also wanted this feature for years, pwa are looking so natural 🔜!

  • @mohhackz4167
    @mohhackz4167 2 года назад +1

    This is insane ! Mashallah ! I like how the web is evolving very fast year after year.

  • @piusijachi2763
    @piusijachi2763 2 года назад

    Give this man a channel

  • @shinomitsu7798
    @shinomitsu7798 2 года назад

    This is so good, I wanted this for so long

  • @razor21212121
    @razor21212121 2 года назад

    I hope this api is gonna be suported by all browsers in the near future, because i'll be using it a lot!

  • @hosono3918
    @hosono3918 2 года назад

    That explains why Jake made an entire HTTP 203 episode about cross-fade! 😉
    Looks great! I'm looking forward to use it! I love how easy it is to customize using good old CSS!

    • @jakearchibald
      @jakearchibald 2 года назад

      Exactly! We needed true cross-fades for this, so we standardised that separately

  • @paales2
    @paales2 2 года назад +65

    This is genius! Have been working with @framer/motion with layout transitions and this is almost alike! Does this also enable on-page automatic FLIP animations that scales, resizes etc and automatically resolves the animation?

    • @jakearchibald
      @jakearchibald 2 года назад +9

      Right now it acts over the whole page, so it might not be appropriate for things when only happen in part of the page (but maybe it's fine in a lot of cases). There's already a github issue open to explore this where the effect is rooted to a smaller area of the page.

    • @rijkvanwel
      @rijkvanwel 2 года назад +4

      @@jakearchibald that would be very helpful, e.g. in case the next “page” opens in a modal while the previous page stays visible in the background (example, opening a Trello card or photo from a gallery)

  • @ashy7198
    @ashy7198 2 года назад +1

    Did I just see DGD on a google dev video. What the? Someone at google has legit music taste.

  • @GavHern
    @GavHern 2 года назад

    this is going to be huge!!

  • @oussamabouchebak6877
    @oussamabouchebak6877 2 года назад +1

    This is looking quite awesome!

  • @xQudo
    @xQudo 3 месяца назад

    5:12 ah yes the start of "ToDo / to be fixed" comments in the code
    Love the attention to detail throughout the whole video, it's just something most apps lacks nowadays.

  • @rameshsrivastavachandra
    @rameshsrivastavachandra 2 года назад

    This is so beautifully done 💖 THANKS JAKE

  • @JohnFarrellDev
    @JohnFarrellDev 2 года назад

    Really cool, hope it is supported well across browsers.

  • @AndreaRiezzo
    @AndreaRiezzo 2 года назад

    The whole video: it's so interesting, looking forward to use the APIs
    at 9:43 ... whaaaaaaa I want them now!

  • @carannar
    @carannar 2 года назад

    This looks fantastic! Soooo much potential

  • @ManojKumar-op7ot
    @ManojKumar-op7ot 2 года назад +1

    This is a major change!

  • @keharacek
    @keharacek 2 года назад +1

    Damn, this looks pretty amazing! Hope this catches attention :O

  • @cat-.-
    @cat-.- 2 года назад +1

    Good. Now we can expect safari to have this in 6-7 business years

  • @peternicholson26
    @peternicholson26 2 года назад +1

    I'm definitely going to be playing with this. Just launching my agencies new website and the page transitions from other Frameworks were a nightmare to mix in with smooth scrolling and gsap, so I left it for version 1.1. Something like this could be the future 💪

  • @TheOtherMattPerry
    @TheOtherMattPerry 2 года назад +36

    This looks great! Being able to encapsulate targets as images will make things a lot more supportive. How does it combine with WAAPI or other JS animations? It would be great to target this stuff with spring animations, independent x/y transitions etc.

    • @KangJangkrik
      @KangJangkrik 2 года назад

      CSS animation is independent except via class name, I don't think that would be easy

  • @the-web-scraping-guy
    @the-web-scraping-guy 2 года назад +1

    This guy is super entertaining

  • @hrgwea
    @hrgwea 2 года назад +6

    Is there a way to control when the "incoming image" is captured?
    For example, a page with a lot of images may take quite some time to load, but the part of the page that's above the fold will load much faster and that's the only part that's needed in order to capture the incoming image.

    • @mildmixchintu1717
      @mildmixchintu1717 2 года назад

      you can possibly use the Document.readyState property to determine if a web page is taking too long to load and override the transition if you may

    • @TheNewton
      @TheNewton 2 года назад

      Right or if we can just set it to a static image. Such as from a dataset of prerendered screens across device types and browser combos.

    • @hrgwea
      @hrgwea 2 года назад

      @@TheNewton That would defeat the purpose of a transition, which is to gradually transit to the actual next page and not a mock-up of the page.

  • @gauravrajghimire6396
    @gauravrajghimire6396 2 года назад +1

    I am weeping with joy here.... What didn't I try...
    Gsap
    Anime js
    Animate.css
    Hover.css
    And nothing worked and i gave up... Finally i now have a hope of seeing the following
    Multiple elements of a dynamic SPA load with smooth and fluent animation that gives the page a sense of continuity... A sense of direction in the chaotic Internet.

  • @michaelflores23
    @michaelflores23 2 года назад

    Excited for this API

  • @BenRangel
    @BenRangel 2 года назад

    Sweet. Perfect Progressive Enhancement where you just take something that already works and make it look nicer for some. But as a non-SPA user I'll wait for the upcoming MPA info