Speed up your Website with Next.js Dynamic Import Lazy Loading

แชร์
ฝัง
  • เผยแพร่เมื่อ 27 ม.ค. 2025

ความคิดเห็น • 34

  • @eminvesting
    @eminvesting ปีที่แล้ว +9

    Been procrastinating dynamic imports for a while, thanks for the explainer ^^ Keep up the good work, looking forward to your channel growing

    • @tenacityzx
      @tenacityzx  ปีที่แล้ว

      Thank you! It means a lot!

  • @Pk_0807
    @Pk_0807 7 หลายเดือนก่อน +2

    That was an clear explanation.. haven't heard this kind of explantion from the other videos. Thanks man

  • @Ziggy0120
    @Ziggy0120 ปีที่แล้ว +2

    This was a really good explanation. Thanks!

  • @Furki4_4
    @Furki4_4 ปีที่แล้ว +2

    Well explained, thank you so much !

  • @Its-InderjeetSinghGill
    @Its-InderjeetSinghGill ปีที่แล้ว

    Well explained. Keep doing the great work ❤

  • @york2301
    @york2301 ปีที่แล้ว +2

    How to use next/dynamic without this button, for example do delay load of certain component on first page load?

    • @tenacityzx
      @tenacityzx  ปีที่แล้ว +2

      You can add the component directly without any conditionals.
      If you want to load the component only when it's visible then you can Intersection Observer.

    • @york2301
      @york2301 ปีที่แล้ว

      @@tenacityzx is this kinda same like frame-motion? I have opacity:0 when component is not in view, when it is opacity is set to 1?

  • @ОлегБаранчиков-ф5у
    @ОлегБаранчиков-ф5у 6 หลายเดือนก่อน +1

    Good explanation

  • @JeromeChung
    @JeromeChung ปีที่แล้ว +1

    thanks,it's really good explanation.

  • @danser_theplayer01
    @danser_theplayer01 3 หลายเดือนก่อน

    I understand that the video is about next.js but literally the import() function is representing the whole concept of a dynamic import, and it works with any javascript.
    Just want people to know that they can do it in vanilla with basically no hand rolling required, you simply make a short function just like making a component. Put up a lodaing screen, await loading, done.
    In one of my projects I'm funneling a lot of modules through a file and importing them as one mean variable. I have 2 folders with similar code and I want only one depending on the environment. So I have an IFEE to load one folder or the other. It's a use case not for fast upfront loading but for conditional loading to remove redundancy.

  • @mohiramansurovna4295
    @mohiramansurovna4295 2 วันที่ผ่านมา

    thank you for explanation

  • @techaddictdude
    @techaddictdude 6 หลายเดือนก่อน +1

    How on earth are you using useState in the server component?

    • @tenacityzx
      @tenacityzx  6 หลายเดือนก่อน

      Good question, this was before the new Next.js updates where if you want to use state or something similar you had to write "use client" at the top of the component.

  • @york2301
    @york2301 ปีที่แล้ว +1

    Great job!

    • @tenacityzx
      @tenacityzx  ปีที่แล้ว

      Thank you! Cheers!

  • @archael18
    @archael18 2 หลายเดือนก่อน

    Couldn't you technically have improved it even further by dynamically importing 'next/dynamic' only in one of the button click events?From my understanding, you would get back to your initial 4kb on initial load since even 'next/dynamic' is not included, then the button click would pull the 15kb from 'next/dynamic' to perform the dynamic import which would immediately be followed up by the 25kb of the heavy component.

    • @benjamin_karlsson
      @benjamin_karlsson หลายเดือนก่อน

      Do you mean something like this?
      import React, { useState } from 'react';
      const DynamicComponentLoader = () => {
      const [HeavyComponent, setHeavyComponent] = useState(null);
      const loadComponent = async () => {
      // Dynamically import 'next/dynamic' only when the button is clicked
      const { default: dynamic } = await import('next/dynamic');
      // Dynamically import the heavy component
      const Component = dynamic(() => import('./HeavyComponent'));
      setHeavyComponent(() => Component);
      };
      return (

      Dynamic Import Example
      Load Heavy Component
      {HeavyComponent && }

      );
      };
      export default DynamicComponentLoader;

    • @archael18
      @archael18 หลายเดือนก่อน

      @benjaminkarlsson6854 Yes. This would delay any loading of components until which time they are needed and not before.

  • @klapaucius515
    @klapaucius515 ปีที่แล้ว +1

    This may help, thank you.
    Can you make a video on how to find out what is causing your FCP to be slow?

    • @tenacityzx
      @tenacityzx  ปีที่แล้ว +1

      I hope you find it useful!
      I'll keep that in mind for future videos.

    • @prabhurao2773
      @prabhurao2773 8 หลายเดือนก่อน +1

      Your async await calls move to server components and start using suspense your FCP will be improved drastically

  • @TheWoselWosel
    @TheWoselWosel 10 หลายเดือนก่อน +1

    Thanks, man! This saved my ass :)

  • @masterv2.045
    @masterv2.045 ปีที่แล้ว

    you rock dude

  • @code_zeal6278
    @code_zeal6278 ปีที่แล้ว +1

    thank you!

    • @tenacityzx
      @tenacityzx  ปีที่แล้ว

      No problem, glad you found it useful!

  • @z1982_
    @z1982_ ปีที่แล้ว +1

    Thanks! But why is it 19kb and not 4.6kb ? :p

    • @tenacityzx
      @tenacityzx  ปีที่แล้ว

      Because the `import dynamic from 'next/dynamic'` has it's own JS size.

  • @mr.random8447
    @mr.random8447 ปีที่แล้ว

    Trade off is extra network call

  • @kairo2891
    @kairo2891 ปีที่แล้ว

    *Promo SM* ✅

  • @janduna4100
    @janduna4100 3 หลายเดือนก่อน

    Get to the point, you repeat one thing 50 times...

    • @tenacityzx
      @tenacityzx  3 หลายเดือนก่อน

      It makes sense to repeat important things so they stick with you, I'll keep this in mind for future videos!