Learn Dynamic Module Imports In 11 Minutes

  Рет қаралды 142,874

Web Dev Simplified

Web Dev Simplified

Күн бұрын

Пікірлер
@oussamakhalfi1751
@oussamakhalfi1751 3 жыл бұрын
this channel + fireship made my brain bigger
@mohammadsiddiq6056
@mohammadsiddiq6056 3 жыл бұрын
Agreeeeeeeed
@CybercoderNaj
@CybercoderNaj 3 жыл бұрын
So fucking trueeee
@divinsmathew
@divinsmathew 3 жыл бұрын
+ Kevin Powell as well!
@bonleofen
@bonleofen 2 жыл бұрын
What? Isn't fireship a troll channel?
@atreysinainadkarni5453
@atreysinainadkarni5453 Жыл бұрын
Hear hear.
@legionsra
@legionsra 3 жыл бұрын
@Web Dev Simplified I would recommend you to extend for another video talking about the caveats or the things to bear in mind about imported modules. For instance, if they launch their own event listeners or any other side effect, when will they die, or how do we release the memory of those imported instances (not the imported file, but the instance), or even more complicated to understand, what would happen if moduleA imports moduleB, which imports moduleA, this definitely will be important for those who share a lot of utils dynamically imported.
@amittraspal
@amittraspal 3 жыл бұрын
The way kyle demonstrates the example...... that's what we call examples. Super useful, and relatable to actual scenarios.
@davzmore3623
@davzmore3623 3 жыл бұрын
Best js tips on KZbin, thank you for the effort to put out these videos.
@grmancool
@grmancool 3 жыл бұрын
The letter g: You want me *Kyle writing the word admin: I want you baby*
@CybercoderNaj
@CybercoderNaj 3 жыл бұрын
My sugar boo
@mtgamer101
@mtgamer101 3 жыл бұрын
Looked for this, was not disappointed.
@MomoCoder
@MomoCoder 3 жыл бұрын
Immediately started searching for this comment :D. I have same issues, esp. function gets really weard when I type c before n.
@CybercoderNaj
@CybercoderNaj 3 жыл бұрын
@@MomoCoder weird*
@MomoCoder
@MomoCoder 3 жыл бұрын
@@CybercoderNaj thanks
@habibishuta4896
@habibishuta4896 3 жыл бұрын
best Programming channel on youtube ♥️♥️♥️
@ShivamJha00
@ShivamJha00 3 жыл бұрын
Best web development channel*
@helgaludwig793
@helgaludwig793 2 жыл бұрын
Wow, thank you so much! this helped me so much cause all modules are switching to import
@ErickPereziChido
@ErickPereziChido Жыл бұрын
Great tutorial! I immediately starting using dynamic module importing in my work project after watching this. Thank you!
@Alessandro-nq3tm
@Alessandro-nq3tm 3 жыл бұрын
Dynamic import + async await = perfection :)
@anticsBack
@anticsBack 3 жыл бұрын
Clear, simple and to the point as always. Thank you Kyle!
@alfiartya23
@alfiartya23 Жыл бұрын
Your explanation for the translation example just blow my mind! Thank you so much Kyle, always delivering good explanation
@jimzhang32
@jimzhang32 3 жыл бұрын
My guy Kyle is always productive!
@johnnydriesen7575
@johnnydriesen7575 3 жыл бұрын
Nice, clear and usefull examples. Thanks Kyle !
@BsiennKhan
@BsiennKhan 2 жыл бұрын
I love your style of explanation, clear, concise, simple with examples. Thank you
@dimitridoroshko
@dimitridoroshko 3 жыл бұрын
"Hi" in Russian is "privét". Thanks for the video, it was helpful to many of those learning JavaScript and myself included :3
@definty
@definty 3 жыл бұрын
I thought that was pasiba
@SealedKiller
@SealedKiller 3 жыл бұрын
@@definty That would be thank you.
@thefreeze6023
@thefreeze6023 3 жыл бұрын
@@definty spasibo, pronounced spasiba means thanks you
3 жыл бұрын
zdarova
@nightcoder5k
@nightcoder5k 3 жыл бұрын
According to Google: “Hi” in Russian - Привет (privyet)
@ozzyfromspace
@ozzyfromspace 2 жыл бұрын
Awesome video Kyle! Super informative. I do have one potential concern though. The way you wrote your code in the last example on conditional imports for your render function, you rerun the import function on every iteration of the shapes array. If your shapes array had 500 objects in it, you’d be running import many, many times! My recommendation here would be to memoize the imports. In particular, you can create an initially empty object, and on your first loop, add a key value pair of the shape and the render function that is returned from the import. Then on subsequent loops, check to see if a render object already exists, and if so, use it. Otherwise create another key value pair. This was a very useful video for me. I knew how to do this with the require syntax in node.js, but had no idea you could do this for module imports. I think I tried once, but it didn’t work cuz I treated it like a synchronous operation when in fact it returned a promise. Very cool stuff bro, keep it up! 🥳✨
@Vibestr
@Vibestr 2 жыл бұрын
would you mind writing out an example of this please?
@GNXClone
@GNXClone 2 жыл бұрын
The first time it's imported, it's in memory and stays resident. Subsequent imports of the same JS file are practically no-ops.
@oluwaseunismaila8522
@oluwaseunismaila8522 3 жыл бұрын
Your tutorials are simply amazing. Confusing concepts clearly explained.
@Sagarclips
@Sagarclips 2 жыл бұрын
One drawback of dynamic import is that Tree shaking is not possible so if you are loading big module, bundler will load all exports from the module. But yes we can eliminate loading of unnecessary modules. That's a big benefit.
@MrQVeeBoo
@MrQVeeBoo Жыл бұрын
very clear explanation and easy to understand with sample. thx.
@dinesh08ification
@dinesh08ification 3 жыл бұрын
Wow, this actually helps a lot, learnt something new today
@shubhamlatiyan7972
@shubhamlatiyan7972 3 жыл бұрын
11:14, async await will not work in foreach loop
@techhype3453
@techhype3453 2 жыл бұрын
super teaching style great explanation
@ChrisAthanas
@ChrisAthanas 3 жыл бұрын
Always clear and no fluff Props
@erikuriegas97243
@erikuriegas97243 2 жыл бұрын
Thank you for what you do, you have truly helped me understand something than can be so complex
@GNXClone
@GNXClone 2 жыл бұрын
Wow! Nice! "This is going to save us time, memory and space" I'm curious to know what the difference is between memory and space. I've always considered memory === space.
@NgocNamNguyenHcm
@NgocNamNguyenHcm 3 жыл бұрын
10:33 in this last example, does this code load/import 3 times, in stead of 2 times according to the original code?
@duffscs
@duffscs 3 жыл бұрын
Probably not thanks to browser caching
@WebDevSimplified
@WebDevSimplified 3 жыл бұрын
It should only load twice. Since the second time it fetches the file it is already downloaded it will just use the downloaded version.
@NgocNamNguyenHcm
@NgocNamNguyenHcm 3 жыл бұрын
@@WebDevSimplified thank you 😊
@uahnbu
@uahnbu 3 жыл бұрын
If you include IIFE functions in the lib, such as console.log, varA++, etc, when you import it multiple times, these IIFE functions will only be called once, due to the behavior of caching.
@legionsra
@legionsra 3 жыл бұрын
@@WebDevSimplified I just checked this, and it is kept in memory, like when you add < script type="module" > to a page. There will be no more networks calls, not even for the cached version, if you refresh the page, then you will get the cached (or from service workers) if headers allows so, and then back to - only memory - usage.
@bhaveshverma8629
@bhaveshverma8629 3 жыл бұрын
Very Nice tutorials. The way use explain is amazing. I always saw your tutorial and get filled with knowledge. Thanks for putting out amazing content.
@LeoPlaw
@LeoPlaw 3 жыл бұрын
Awesome! I was looking for this solution months ago. Better late than never! Now I have some code to update. =)
@achtube85
@achtube85 3 жыл бұрын
Awesome and clear explanations, as always! Gracias, Kyle!
@imsarvesh_
@imsarvesh_ 3 жыл бұрын
Why this channel doesn’t have 1M subscribers?
@JackBrunsion
@JackBrunsion 3 жыл бұрын
Great explanation and demonstration!
@nikolromick6134
@nikolromick6134 3 жыл бұрын
Would be great if you show your network loading while demonstrating code usage with example
@CottidaeSEA
@CottidaeSEA 2 жыл бұрын
Sort of but at the same time it wouldn't. The issue with these examples is that they are too small in scale. It would therefore not have a big enough impact on the network. This is similar to how you'd use async or defer to load scripts in a browser by the way.
@ManuelLopera
@ManuelLopera 3 жыл бұрын
This is very useful when using huge libs like pdf.js 👏👏👏
@PierreSoubourou
@PierreSoubourou 3 жыл бұрын
thanks for your videos text seems to be getting a little bigger, that's great
@Musikur
@Musikur 3 жыл бұрын
This is actually really cool, I did not know about this.
@ArKy326
@ArKy326 3 жыл бұрын
Always learning new with js tnx mr. Kyle!
@sudarshanprajapati9742
@sudarshanprajapati9742 3 жыл бұрын
This video is really valuable for me. Thanks
@ThugLifeModafocah
@ThugLifeModafocah 3 жыл бұрын
Very good tips indeed. Thanks.
@agoodcode
@agoodcode 3 жыл бұрын
Great content as always 👍🏻👍🏻👍🏻
@HELIOSsanta
@HELIOSsanta Жыл бұрын
Hello my dear how You doing? Man You did a great job thanks so much your thought change Me a lot thanks so much.
@raghunathvadlakonda810
@raghunathvadlakonda810 3 жыл бұрын
Really Really Worth it. @Kyle you are awesome.
@abhijiths148
@abhijiths148 3 жыл бұрын
Excellent topic... Thanks 👍
@amithbhagat
@amithbhagat 3 жыл бұрын
Thank you Kyle, it is really helpful.
@Aaronmoreno
@Aaronmoreno 3 жыл бұрын
you're the best kyle!
@infinitepurelive
@infinitepurelive 3 жыл бұрын
Awesome content as always
@mrarsenal10vn
@mrarsenal10vn 3 жыл бұрын
Thanks, Kyle. Really useful
@oah8465
@oah8465 2 жыл бұрын
fantastic video, but what does the default: in ==> .then(({default:User,printUser})=>{}) do, if I remove it i get an error. Why type of operation is it doing? (appears at 03:42)
@sreeragmmundayadan6057
@sreeragmmundayadan6057 3 жыл бұрын
Really helpful 👍
@techtonight882
@techtonight882 3 жыл бұрын
Two questions: 1. Wouldn't rectangle.js imported twice now? 2. Since we made forEach function async, and triangle.js is a significantly larger file from rectangle.js, then wouldnt it render rectangle and triangle out of order?
@hnccox
@hnccox 3 жыл бұрын
Me showing up to my boss: "I created a render engine for different shapes" The render engine:
@DisturbedNeo
@DisturbedNeo Жыл бұрын
Only one note, and that's just that the abbreviation for Spanish is "es", as in "España", not "sp"
@HumbertoRincon
@HumbertoRincon 3 жыл бұрын
Useful use cases, thanks Kyle
@bryanenid1228
@bryanenid1228 3 жыл бұрын
What is the advantages of using this than using require() ? Just the async?
@avneet12284
@avneet12284 3 жыл бұрын
This was truly great
@habibishuta4896
@habibishuta4896 3 жыл бұрын
love your content man
@willyhorizont8672
@willyhorizont8672 2 жыл бұрын
thanks you're really helpful
@haoranxu4465
@haoranxu4465 3 жыл бұрын
This is so useful☺️!
@eli-shulga
@eli-shulga 3 жыл бұрын
Cool, two questions: 1. what about real life apps were you have a bundled code... So if you have only 1 bundle file (yea thats not good but is the reality with a lot of apps) then you will still have to import the js file.. so what does the dynamic import saves? The run time memory? 2. Wont this effect on run time performance? Now that you import in run time, you will have to perform the import with the action itself which should decreases runtime performance, so in essence you are trading loading performance for run time performance right? Also would be nice to see your take on splitting a 1 bundle app to 2 bundles when the second loads dynamically as shown here but with the full flow going back to importing the bundle from the server/cdn Great stuff Thanks
@tanaseadrian8305
@tanaseadrian8305 2 жыл бұрын
awesome tutorial
@sean9829
@sean9829 3 жыл бұрын
Wow. Didn’t know about this one. Thanks
@m0hammedimran
@m0hammedimran 3 жыл бұрын
I love your videos. But please increase the volume. I was wondering if my speaker was working
@Biersasam
@Biersasam 2 жыл бұрын
10:39 correct me if I am misunderstanding, but if we use a forEach and have duplicate shape types. Won't this code import the same script multiple times?
@SRG-Learn-Code
@SRG-Learn-Code Жыл бұрын
yeah, what about that... probably it got cached, but is this something to avoid?
@stanislavmalyshev5209
@stanislavmalyshev5209 3 жыл бұрын
Good job!
@khoaiviet7436
@khoaiviet7436 3 жыл бұрын
Thank you. This very helpful
@RadiGamer
@RadiGamer 2 жыл бұрын
damn, that was useful! Thanks a lot man :D
@karolsyta1742
@karolsyta1742 3 жыл бұрын
Can I use async/await with default import name as in translations example? Where to put try .. catch then?
@kirayatail
@kirayatail 3 жыл бұрын
Hey, I learned something today. Have a like!
@me_manish_prajapati
@me_manish_prajapati 3 жыл бұрын
Some questions: Should we use this in react-redux? For actions and dispatch It'll download the whole file and then by destructuring we will pick one method, so is there any method where we can download one method from .js file? Thanks, Kyle, You always know what we need to know about the Web.
@kalokal5812
@kalokal5812 3 жыл бұрын
I'm torn between feeling like this is amazing for performance and getting rid of 50 lines of imports at the top of all my files and it making the code itself less readable... Also how well does this work with automatically updating imports (e.g. in VSCode when you change file names)?
@Vipers992
@Vipers992 3 жыл бұрын
Honestly if I did these dynamic imports in any corporate codebase with 30+ engineers collaborating on it, people will really think i'm just being pretentious and not sticking with the format. All the files get bundled anyway.
@jhandgreat7079
@jhandgreat7079 3 жыл бұрын
Thanks bro!
@kappitain
@kappitain 3 жыл бұрын
Thanks for the video, great content ! Just a quick note though it's interesting to see what happen on the network's dev tools during the import. For example, in the last example, when doing foreach with the same file name, it won't resend the request for the same file, instead, it'll use the one that's already downloaded (I think it's because of the cache mechanism from the browser).
@vhawkins8289
@vhawkins8289 3 жыл бұрын
This is cool. 😎 Currently, are the files downloaded each time the code is run?
@hiroyukinumaguchi1984
@hiroyukinumaguchi1984 3 жыл бұрын
Thank you!!
@Lahiru_Udana
@Lahiru_Udana 3 жыл бұрын
awesome. thanks
@lasithadulshan7357
@lasithadulshan7357 3 жыл бұрын
Shot & Sweet
@sky78710
@sky78710 2 жыл бұрын
Can you explain that with using webpack jsnop bundles so that selection bundle dynamically. Please.
@muhamedkaric4247
@muhamedkaric4247 3 жыл бұрын
In the last example if we have 100 rectangles in the array it will load the file with render function each time, that costs ? Also if we use import in a function that is called so many times with same parameters than we have bad decision. We should be very careful with dynamic loading. Translation files are the best example when to use dynamic loading.
@igorswies5913
@igorswies5913 3 жыл бұрын
I think there is caching so that one file only gets imported once but I might be incorrect when dealing with dynamic imports
@franciscod5987
@franciscod5987 3 жыл бұрын
Hi Kyle I had a question about the last example, so when you go through the forEach loop you run the ‘import’ function for every item in the array, does that mean you RE-import the files every time?
@me_manish_prajapati
@me_manish_prajapati 3 жыл бұрын
I think, once the file is downloaded it will use downloaded code only. So it'll check whether do we have that file or not. ( Same as React lazy loading works )
@CybercoderNaj
@CybercoderNaj 3 жыл бұрын
Are there any use cases for dynamic importing in React or Vue?
@the_BetaDev
@the_BetaDev 3 жыл бұрын
Maybe in importing a component dynamically only in case you need to use it
@kirponomarenko
@kirponomarenko 3 жыл бұрын
Lazy loading. User scrolls page and only then component loads. Probably good for landings.
@annguyenhoangphu451
@annguyenhoangphu451 3 жыл бұрын
I have a question that when we use multiple time the dynamic import of the same is file, do the browser will download every single time or just one time and save in memory?
@pokefan2711
@pokefan2711 3 жыл бұрын
{default: User, printUser} Shit I didnt know this existed. I already used a lot of destructurings, but not this. Thanks!
@redwilliams1804
@redwilliams1804 3 жыл бұрын
Please tell me why your into sounds like Nimbasa city from Pokemon Black/White? I love it!
@jenstornell
@jenstornell 3 жыл бұрын
In the last example you are importing two files that are the same. Will it be loaded twice or one time and then cached?
@md.asifal-mahmud5952
@md.asifal-mahmud5952 2 жыл бұрын
Thanks a lot
@naveenda2064
@naveenda2064 3 жыл бұрын
I heard about dynamic import is not able to do the treeshaking
@xAxtroz
@xAxtroz 3 жыл бұрын
Curious, are you using Promise.then((args) => { console.log(args) }) instead of Promise.then(console.dir) out of habit, to be explicit or for another reason? Mind sharing your thoughts? I'm talking in a scenario where you just want to dump something in the console.
@someoneelse8103
@someoneelse8103 3 жыл бұрын
And what if I want to reuse it few times? Would it be a good idea to create a function that might take an argument and inside I call this dynamic module and do something? Also, when there are few different things I gotta do import("./some.js").then(({somefunc}) => { somefunc }) and lower goes import("./another.js").then(({anotherfunc}) => { anotherfunc }) do I need to use dynamic import when it's not divided by logic in the case when a user can only get to one of these points but instead just load it when he did? It could be quite optimizing but it is not supposed to use like in EVERY place where you import something right? more realistic scenario. If I have to call multiple Axios requests do I call it like that all the time? or just import it as we normally do?
@nightcoder5k
@nightcoder5k 3 жыл бұрын
Good stuff
@brycetwyman
@brycetwyman 2 жыл бұрын
Does this process change at all if I wish to import async functions?
@madhavmadhusoodanan1877
@madhavmadhusoodanan1877 3 жыл бұрын
Yaaayyyy i got in within the first 1k views I feel blessed :)
@trinhle7227
@trinhle7227 3 жыл бұрын
3:09 anyone can tell me how to do that. thanks
@Asty__
@Asty__ 3 жыл бұрын
How different would dynamic module imports would be in Node.js? Can we use the same Promise method inside of a function with the "require" syntax?
@mzaini30
@mzaini30 3 жыл бұрын
Set up your project as ESM. Add "type": "module" in package.json
@shaikshavalisyed2012
@shaikshavalisyed2012 3 жыл бұрын
One of the best features of js.
@yewyewxd
@yewyewxd 2 жыл бұрын
does async works in forEach? I thought it only works in for loop
@7heMech
@7heMech 6 ай бұрын
Thanks.
@akshaygadekar9926
@akshaygadekar9926 Жыл бұрын
But what if whichever file we imported as request is getting used in another component as well, there we will do import request again? Then better be it in bundler itself
@m12652
@m12652 Жыл бұрын
Nice!
@DuyTran-ss4lu
@DuyTran-ss4lu 3 жыл бұрын
Awesome!
@the_BetaDev
@the_BetaDev 3 жыл бұрын
In the last case, will it import every time the loop runs? like we run render rectangle twice so will it import that twice because it's in a loop?
@SamareshMaity231
@SamareshMaity231 3 жыл бұрын
thank you
Every JavaScript Developer Has Made This Mistake With Functions
7:17
Web Dev Simplified
Рет қаралды 108 М.
Another 5 Must Know JavaScript Features That Almost Nobody Knows
22:42
Web Dev Simplified
Рет қаралды 215 М.
Caleb Pressley Shows TSA How It’s Done
0:28
Barstool Sports
Рет қаралды 60 МЛН
Jaidarman TOP / Жоғары лига-2023 / Жекпе-жек 1-ТУР / 1-топ
1:30:54
Learn JavaScript Event Listeners In 18 Minutes
18:03
Web Dev Simplified
Рет қаралды 605 М.
Speed Up Your React Apps With Code Splitting
16:50
Web Dev Simplified
Рет қаралды 397 М.
Импорт и экспорт JavaScript. На реальном примере
24:27
WebDev с нуля. Канал Алекса Лущенко
Рет қаралды 51 М.
The CSS Display Property is Changing Forever
15:20
Web Dev Simplified
Рет қаралды 79 М.
Learn DOM Manipulation In 18 Minutes
18:37
Web Dev Simplified
Рет қаралды 1 МЛН
Require vs Import Javascript
22:39
Monsterlessons Academy
Рет қаралды 81 М.
Learn JavaScript Generators In 12 Minutes
12:11
Web Dev Simplified
Рет қаралды 181 М.
5 JavaScript Concepts You HAVE TO KNOW
9:38
James Q Quick
Рет қаралды 1,4 МЛН
5 MORE Must Know JavaScript Features That Almost Nobody Knows
18:05
Web Dev Simplified
Рет қаралды 180 М.