Sam Selikoff: Improving developer and user experience with nested layouts in Next.js

Поделиться
HTML-код
  • Опубликовано: 21 ноя 2024
  • НаукаНаука

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

  • @alfonsocartes
    @alfonsocartes 2 года назад +63

    So many concepts understood in one video. Awesome! Thank you Sam

    • @sma1015
      @sma1015 Год назад +1

      and in just 23minutes... damn

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

    Sam is a great educator. He paces his talks/videos quite nicely like a melody. You get introduced to a simple API, then a problem, then a natural solution that intuitively makes sense, then some fun with it, and then a great climax to what you just learnt.

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

      are we still talking about youtube videos or

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

      @@swyxTV _sorry children_

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

    Wow I can't believe you can hold space to move the MacOS screenshot selection!!! This has changed my life.
    Great explanation of /app as well :)

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

      I never knew you could do that either lol

  • @im-a-trailblazer
    @im-a-trailblazer Год назад

    It's an absolute joy to learn a framework this way.

  • @ichibanfuego
    @ichibanfuego 2 года назад +72

    am i watching a vscode masterclass or a layouts demo

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

    Having built only a small number of frontend mvp apps I really appreciate that the new next hits all the common dev concerns that even I have run upon. So convenient.

  • @DMZT_dhruv
    @DMZT_dhruv 7 месяцев назад

    Hey bro this is the best tutorial of nested layout I have ever seen, your way of explaining is just so good loved this video!!

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

    I was to start a new project downloaded next-12 yesterday Now switching to next-13. Very well explained video Thanks Sam.

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

    woah cool to see Bradley Cooper giving explanations about next 13 🙏

  • @ginger-viking
    @ginger-viking Год назад

    Love Sam's teaching style

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

    I think I've watched this video almost 5 even the 2 stages of the conference, it was awesome tbh! Thanks to the full team, amazing work here!

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

    I am happy to watch you on Vercel channel.

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

    I didn't even notice 23 minutes have gone by. Thank you for this awesome release Vercel! Can't wait to get my hands dirty!

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

    Wonderful way to explain. Next 13 has many features that reduced the doubts I had to understand ssr or csr. Thank you very much!

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

    Such a great talk! Thanks Sam, can't imagine making this content easier to understand

  • @shift-happens
    @shift-happens 2 года назад

    The segment from useSelectedLayoutSegment is just awesome :)

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

    Great video Sam. A lot of concepts inside one video and hands-on examples. congratz

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

    just wow video. so many good things I learnt from just a single video. great way to teach

  • @synt-x6458
    @synt-x6458 2 года назад

    well explained. anyone else excited by these new features?

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

    Easily the best conf talk ... nicely done!

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

    Yeah, I went from "dunno if I'll get this to work" to already thinking ahead to migrating my blog as a test project. Gonna wait for the docs to be updated and current projects to get finished and give it a try :)

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

    You were an awesome presenter, thanks enjoyed the video.

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

    Always enjoy your great videos Sam! You are an amazing teacher. I'm sure you get a bit of smirk on your face how similar this feels to Ember land with even more flexibility to take things further with the server side and client side paradigms which are awesome. I'll definitely be giving the new layout stuff a try this week.

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

      You got it! Love seeing more and more of the best patterns making their way into Next.js 🙂

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

    WOW that was a quick but very concrete explanation, thank you.

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

    Very professional and crisp. Thanks SAM!

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

    Wow, the new features seem amazing...Thank you

  • @drakongames5417
    @drakongames5417 11 месяцев назад +1

    how are you using those commands(11:41) without going to network tab. whats the shortcut bring out run and enter command there

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

    Very clear and informative video. I would like too see more examples

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

    Thank you for the clear explanation. I can't wait to use nextjs 13 in my new projects.

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

    This video is absolutely amazing.

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

    please share the github link to this project so we can see the version of different package i am stuck

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

    Sam Selikoff: Improving learning experience

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

    so well explained and enjoyable to watch🔥

  • @henriquematias1986
    @henriquematias1986 Год назад +1

    Would be great to see useSWR running on top of those statically rendered pages! So new data could be loaded at runtime. Also the server side code to be updated from time to time

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

    Thank you for such a valuable video 👏

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

    This is awesome stuff you guys have done.
    Just a question for Sam concerning layout.
    How do I create protected layouts, such that, the layout at the root level of my project doesn't show on a protected page/route(using middleware for protected routes).
    Looking forward to a reply. Thanks

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

    Wow! This video is excellent! Layout was daunting to me until I watched this video. That is very well explained! Thank you so much

  • @jbjiostore626
    @jbjiostore626 Год назад +1

    I am facing trouble when using redux with next js app directory

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

    This talk was great, I wish they showed how to do mutations(post reqs) as well with the server components, because when you go client side for interactivity you lost the backend capabilities.

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

    Amazing explanation 🔥🔥 Nextjs forever 🔥🔥

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

    Very good video, the pacing is perfect. How can I setup the hot reload you are using, the get instant feedback on localhost?

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

    Banger as always

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

    great talk Sam!

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

    Sam is awesome

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

    So goood! Such learn... 🙂 Maybe a stupid question though. 22:30 - what if I change something in my DB, for example year of LoTR from 2001 to 2002. Will this update or I have to rebuild the next.js app again (or if I add a new movie)

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

    Great video !

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

    Sam is the best!

  • @AhmadAbdulSamad
    @AhmadAbdulSamad 11 месяцев назад

    liked the start music

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

    awesome video. qq: why not const for all those variable you are never going to update, why use let?

  • @manoj-k
    @manoj-k 2 года назад

    My favourite man is here

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

    Love the new routing system, migrate api routing too pls 🙏

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

    So helpful thank you so much

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

    I think this video is a bit outdated, we can simply use await inside a Server component, use hook is only required in Client components.

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

    AMAZING !!!

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

    This is very useful.

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

    Holy cow ! Awesome thx for the video

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

    Is there a difference for using useSelectedLayoutSegment vs useRouter and reading the url?

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

    Great video. Explained new concepts like piece of cake :)

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

    Sam, thanks for you great presentation. Could you share this example with us?

  • @basics-school
    @basics-school Год назад

    so much details in this talk but while I use segment it with group route i get the segment as (auth) like this so how can i set the active state in this scenerio

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

    Fantastic!

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

    How can I open that little window at the top when you select something you wanna wrap in the JSX?

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

    Hi, Sam two issues:
    1. when I use in nav-link.tsx: "let segment = useSelectedLayoutSegment();" I get " No selected layout segment below the current level"
    2. When i use "import { experimental_use as use } from "react";" I get "react__WEBPACK_IMPORTED_MODULE_1__.experimental_use) is not a function"

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

      Any chance you can share a reproduction? I'd be happy to take a look!

    • @ray-lee
      @ray-lee 2 года назад +2

      you can just import use with "import { use } from "react"

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

      @@ray-lee tk! this solve the second problem!

    • @9662Mario
      @9662Mario 2 года назад

      For the first issue, like at me, the error presents when "segment" in on "/". If you look at /movies it work fine.

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

      I am having the exact same issue

  • @GurpreetSingh-zn1fd
    @GurpreetSingh-zn1fd Год назад

    Super!

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

    I the love the way you are explain things, great. pls also explain with auth and global state.

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

    I’ve been looking for this

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

    excellent !!!

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

    This is great but im wondering how to bring back the context tree from _app.tsx (for ui and auth providers)

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

      @@jeremytenjo great! Thank you very much for taking the time to answer

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

    really good video

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

    Question: Around 6:45, after you get the client-component setup (via 'use client') we see that the console.log(href) prints each route *twice* in the Chrome dev tools for each page refresh. Why twice?

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

      This is because React 18, with strict mode enable.

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

    Thanks! very nice explanation (as always)...

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

    useSelectedLayoutSegment not working :p

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

    loading page is cute but a progress bar on the top is better , youtube , github it just looks so good without subjecting people to page wide loading spinners

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

    App layout is stable in Next Js 13.4

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

    generatestaticparams what happen if from the api the content has been updated ?

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

    Sick

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

    Ou, great thing! I tried using the same files, and experimental_use is throwing an error as its not a function of react on movies/page.js

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

      Same issue, change the react version in package.json to "experimental", but still fail

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

      I think it is due to the fact I was using typescript and the @types/react is not exporting this hook.

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

    Awesome❤

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

    Anyone know how to use UI Components for app folder new version ?

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

    That's Sam!

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

    Mom: we have Remix at home
    Remix at home: Next 13

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

    Really great developments, thank you! Though I am a little concerned about how hideous was that "loading" flicker every time you navigated to Movies. It's fine when you land on that page, but navigating to it (for my standards, at least) will require a much more elegant solution than that.

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

      Simple enough. Have the loading component return null unless it's been 200ms or something, in which case, show a skeleton loader. That way you're not flashing it for every little thing, but when things actually are taking 1s+ to load, people will get some sort of feedback.

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

    This is cool. Do you have a personal RUclips channel. I love how you explain stuffs

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

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

    Please do more video Thank you

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

    Hello, can you update this tutorial...it has changed now

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

    Pls share the git hub link of that code.

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

    Hey hi.
    What shortcuts u used for changing the throttling

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

      Sorry what do you mean by throttling?

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

      @@samselikoff Network speed throttling/reducing

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

      @@mayank1513 Ah!  + Shift + P to bring up the command palette, then "Go online", "Enable fast 3G throttling", and "Enable slow 3G throttling".

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

    i think i still like the old way

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

    Need typescript ver 😢 But helpful content anyway. Thank you very much 🥰🥰

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

      It's a really simple example, I don't think you need to worry about TS, it doesn't change that much

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

    Found nextjs.13 very buggy with MUI cos it took to much time to compile things and is using to many modules on compilation.

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

    anyone else weirded out by how many rerenders happen on the client when navigating between pages. monka

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

    How is the Loading component being used while fetching? NextJs picked it up automatically?

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

      yes

    • @ayoubahabchane
      @ayoubahabchane Год назад +1

      "loading" is a special file name that NextJs recognizes. If you supply nextJs with a file named "loading" inside a certain folder/segment, NextJs will use that file/component as the loading placeholder for that particular segment.

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

    Why the server was hitted so many times during the build ? Is this a bug?

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

      This was due to me using an early version of Next 13 when coding the demo

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

    i am new. how do you get browser window in visual code

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

      It's not really in VS-Code, its just sorted on left/right side on the monitor Ithink :)

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

    Is someone else getting false on index route "/"?

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

    what about api folder? Will it be supported also in the future?

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

      It didn't go away, you can use it as always

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

      Will be supported in the future when they find a good solution for it they said.

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

    I'm here for the third time watching this. Everytime I had different feelings about it. First I was amazed, then I got worried, now I'm not so sure. Like, it was your responsibility to know how/when/where in the flow you should call a loader, now it is like magic... It can just bind you too much to the tool making you not much interchangeable to others tools and the market. I don't know, maybe I'm talking 🐄💩 but as awesome these changes are, they seems dangerous too.

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

    Noob here. Where are your .next and node_modules folders? My project looks nothing like this to start

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

      I use the Files: Exclude setting in VSCode to ignore everything in my .gitignore file from the tree explorer.

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

    11:41 how to do that ?

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

      +Shift+P to bring up the DevTools command palette