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

Поділитися
Вставка
  • Опубліковано 4 лис 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

  • @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.

  • @im-a-trailblazer
    @im-a-trailblazer Рік тому

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

  • @DMZT_dhruv
    @DMZT_dhruv 6 місяців тому

    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!!

  • @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!

  • @kenny7385
    @kenny7385 2 роки тому +3

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

  • @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.

  • @TomHermans
    @TomHermans Рік тому

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

  • @alsherifkhalaf7385
    @alsherifkhalaf7385 2 роки тому

    I am happy to watch you on Vercel channel.

  • @shift-happens
    @shift-happens 2 роки тому

    The segment from useSelectedLayoutSegment is just awesome :)

  • @emalorenzo2415
    @emalorenzo2415 2 роки тому +1

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

  • @ginger-viking
    @ginger-viking Рік тому

    Love Sam's teaching style

  • @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)

  • @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!

  • @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.

  • @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

  • @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 🙂

  • @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!

  • @_peterferguson
    @_peterferguson 2 роки тому

    Easily the best conf talk ... nicely done!

  • @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

  • @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?

  • @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?

  • @indianappguy
    @indianappguy 2 роки тому +1

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

  • @larrydevops
    @larrydevops 2 роки тому

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

  • @prabeshregmi3372
    @prabeshregmi3372 2 роки тому +1

    Sam Selikoff: Improving learning experience

  • @omkarkulkarni3644
    @omkarkulkarni3644 2 роки тому +1

    Very professional and crisp. Thanks SAM!

  • @soymartiinez
    @soymartiinez 2 роки тому

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

  • @vitriowibisono2875
    @vitriowibisono2875 2 роки тому

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

  • @sturmenta
    @sturmenta 2 роки тому +1

    so well explained and enjoyable to watch🔥

  • @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.

  • @questionyourbeliefs
    @questionyourbeliefs Рік тому

    This video is absolutely amazing.

  • @jbjiostore626
    @jbjiostore626 Рік тому +1

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

  • @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.

  • @lutif1415
    @lutif1415 2 роки тому

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

  • @quantumrim3805
    @quantumrim3805 Рік тому

    Thank you for such a valuable video 👏

  • @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

  • @eliuddyn
    @eliuddyn 2 роки тому +1

    Amazing explanation 🔥🔥 Nextjs forever 🔥🔥

  • @senkasim
    @senkasim 2 роки тому

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

  • @swyxTV
    @swyxTV 2 роки тому +1

    great talk Sam!

  • @drakongames5417
    @drakongames5417 10 місяців тому +1

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

  • @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

  • @BrianRAmolo
    @BrianRAmolo Рік тому

    Great video !

  • @igrb
    @igrb 2 роки тому

    Banger as always

  • @wchorski
    @wchorski Рік тому

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

  • @labnol
    @labnol Рік тому

    This is very useful.

  • @minnow1337
    @minnow1337 2 роки тому

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

  • @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

  • @codex6634
    @codex6634 2 роки тому

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

  • @othmaneaoubid6896
    @othmaneaoubid6896 2 роки тому +1

    useSelectedLayoutSegment not working :p

  • @gustavomonteiro2087
    @gustavomonteiro2087 2 роки тому

    Sam is the best!

  • @AhmadAbdulSamad
    @AhmadAbdulSamad 11 місяців тому

    liked the start music

  • @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

  • @pavankjadda
    @pavankjadda 2 роки тому

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

  • @Infante1979
    @Infante1979 Рік тому

    So helpful thank you so much

  • @manoj-k
    @manoj-k 2 роки тому

    My favourite man is here

  • @rammehar5531
    @rammehar5531 2 роки тому

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

  • @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

  • @ogunmokunademola7292
    @ogunmokunademola7292 2 роки тому

    This is cool. Do you have a personal UA-cam channel. I love how you explain stuffs

  • @warofsigmar34000
    @warofsigmar34000 2 роки тому

    Holy cow ! Awesome thx for the video

  • @amirnoorani5017
    @amirnoorani5017 Рік тому

    Sam is awesome

  • @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.

  • @luisllaboj
    @luisllaboj Рік тому

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

  • @uziboozy4540
    @uziboozy4540 2 роки тому

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

  • @raajnadar
    @raajnadar Рік тому

    App layout is stable in Next Js 13.4

  • @notshbn
    @notshbn 2 роки тому

    I’ve been looking for this

  • @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.

  • @HarshDivecha_FTR
    @HarshDivecha_FTR Рік тому

    AMAZING !!!

  • @neil_from_future
    @neil_from_future 2 роки тому

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

  • @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.

  • @JasonChannelOne
    @JasonChannelOne 2 роки тому

    Fantastic!

  • @harelpanker
    @harelpanker 2 роки тому

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

  • @inasuma8180
    @inasuma8180 2 роки тому

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

  • @gabrielrock
    @gabrielrock 2 роки тому +1

    really good video

  • @majidtaei4251
    @majidtaei4251 Рік тому

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

  • @eyotajr
    @eyotajr Рік тому

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

  • @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.

  • @GurpreetSingh-zn1fd
    @GurpreetSingh-zn1fd Рік тому

    Super!

  • @anhvuuc8693
    @anhvuuc8693 2 роки тому

    Please do more video Thank you

  • @sK4hsCz
    @sK4hsCz Рік тому

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

  • @anuroop748
    @anuroop748 2 роки тому

    excellent !!!

  • @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.

  • @whoIsDeck
    @whoIsDeck 2 роки тому

    That's Sam!

  • @ahmedabbas3981
    @ahmedabbas3981 Рік тому

    Pls share the git hub link of that code.

  • @AuxiliaryOfficial
    @AuxiliaryOfficial 2 роки тому

    i think i still like the old way

  • @ashutoshsingh8867
    @ashutoshsingh8867 2 роки тому

    Awesome❤

  • @sayandcode
    @sayandcode 2 роки тому

    Sick

  • @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".

  • @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.

  • @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.

  • @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

  • @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.

  • @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 :)

  • @mastan419
    @mastan419 2 роки тому

  • @eyotajr
    @eyotajr 2 роки тому

    11:41 how to do that ?

    • @samselikoff
      @samselikoff 2 роки тому

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