@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.
@amittraspal3 жыл бұрын
The way kyle demonstrates the example...... that's what we call examples. Super useful, and relatable to actual scenarios.
@davzmore36233 жыл бұрын
Best js tips on KZbin, thank you for the effort to put out these videos.
@grmancool3 жыл бұрын
The letter g: You want me *Kyle writing the word admin: I want you baby*
@CybercoderNaj3 жыл бұрын
My sugar boo
@mtgamer1013 жыл бұрын
Looked for this, was not disappointed.
@MomoCoder3 жыл бұрын
Immediately started searching for this comment :D. I have same issues, esp. function gets really weard when I type c before n.
@CybercoderNaj3 жыл бұрын
@@MomoCoder weird*
@MomoCoder3 жыл бұрын
@@CybercoderNaj thanks
@habibishuta48963 жыл бұрын
best Programming channel on youtube ♥️♥️♥️
@ShivamJha003 жыл бұрын
Best web development channel*
@helgaludwig7932 жыл бұрын
Wow, thank you so much! this helped me so much cause all modules are switching to import
@ErickPereziChido Жыл бұрын
Great tutorial! I immediately starting using dynamic module importing in my work project after watching this. Thank you!
@Alessandro-nq3tm3 жыл бұрын
Dynamic import + async await = perfection :)
@anticsBack3 жыл бұрын
Clear, simple and to the point as always. Thank you Kyle!
@alfiartya23 Жыл бұрын
Your explanation for the translation example just blow my mind! Thank you so much Kyle, always delivering good explanation
@jimzhang323 жыл бұрын
My guy Kyle is always productive!
@johnnydriesen75753 жыл бұрын
Nice, clear and usefull examples. Thanks Kyle !
@BsiennKhan2 жыл бұрын
I love your style of explanation, clear, concise, simple with examples. Thank you
@dimitridoroshko3 жыл бұрын
"Hi" in Russian is "privét". Thanks for the video, it was helpful to many of those learning JavaScript and myself included :3
@definty3 жыл бұрын
I thought that was pasiba
@SealedKiller3 жыл бұрын
@@definty That would be thank you.
@thefreeze60233 жыл бұрын
@@definty spasibo, pronounced spasiba means thanks you
3 жыл бұрын
zdarova
@nightcoder5k3 жыл бұрын
According to Google: “Hi” in Russian - Привет (privyet)
@ozzyfromspace2 жыл бұрын
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! 🥳✨
@Vibestr2 жыл бұрын
would you mind writing out an example of this please?
@GNXClone2 жыл бұрын
The first time it's imported, it's in memory and stays resident. Subsequent imports of the same JS file are practically no-ops.
@oluwaseunismaila85223 жыл бұрын
Your tutorials are simply amazing. Confusing concepts clearly explained.
@Sagarclips2 жыл бұрын
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 Жыл бұрын
very clear explanation and easy to understand with sample. thx.
@dinesh08ification3 жыл бұрын
Wow, this actually helps a lot, learnt something new today
@shubhamlatiyan79723 жыл бұрын
11:14, async await will not work in foreach loop
@techhype34532 жыл бұрын
super teaching style great explanation
@ChrisAthanas3 жыл бұрын
Always clear and no fluff Props
@erikuriegas972432 жыл бұрын
Thank you for what you do, you have truly helped me understand something than can be so complex
@GNXClone2 жыл бұрын
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.
@NgocNamNguyenHcm3 жыл бұрын
10:33 in this last example, does this code load/import 3 times, in stead of 2 times according to the original code?
@duffscs3 жыл бұрын
Probably not thanks to browser caching
@WebDevSimplified3 жыл бұрын
It should only load twice. Since the second time it fetches the file it is already downloaded it will just use the downloaded version.
@NgocNamNguyenHcm3 жыл бұрын
@@WebDevSimplified thank you 😊
@uahnbu3 жыл бұрын
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.
@legionsra3 жыл бұрын
@@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.
@bhaveshverma86293 жыл бұрын
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.
@LeoPlaw3 жыл бұрын
Awesome! I was looking for this solution months ago. Better late than never! Now I have some code to update. =)
@achtube853 жыл бұрын
Awesome and clear explanations, as always! Gracias, Kyle!
@imsarvesh_3 жыл бұрын
Why this channel doesn’t have 1M subscribers?
@JackBrunsion3 жыл бұрын
Great explanation and demonstration!
@nikolromick61343 жыл бұрын
Would be great if you show your network loading while demonstrating code usage with example
@CottidaeSEA2 жыл бұрын
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.
@ManuelLopera3 жыл бұрын
This is very useful when using huge libs like pdf.js 👏👏👏
@PierreSoubourou3 жыл бұрын
thanks for your videos text seems to be getting a little bigger, that's great
@Musikur3 жыл бұрын
This is actually really cool, I did not know about this.
@ArKy3263 жыл бұрын
Always learning new with js tnx mr. Kyle!
@sudarshanprajapati97423 жыл бұрын
This video is really valuable for me. Thanks
@ThugLifeModafocah3 жыл бұрын
Very good tips indeed. Thanks.
@agoodcode3 жыл бұрын
Great content as always 👍🏻👍🏻👍🏻
@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.
@raghunathvadlakonda8103 жыл бұрын
Really Really Worth it. @Kyle you are awesome.
@abhijiths1483 жыл бұрын
Excellent topic... Thanks 👍
@amithbhagat3 жыл бұрын
Thank you Kyle, it is really helpful.
@Aaronmoreno3 жыл бұрын
you're the best kyle!
@infinitepurelive3 жыл бұрын
Awesome content as always
@mrarsenal10vn3 жыл бұрын
Thanks, Kyle. Really useful
@oah84652 жыл бұрын
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)
@sreeragmmundayadan60573 жыл бұрын
Really helpful 👍
@techtonight8823 жыл бұрын
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?
@hnccox3 жыл бұрын
Me showing up to my boss: "I created a render engine for different shapes" The render engine:
@DisturbedNeo Жыл бұрын
Only one note, and that's just that the abbreviation for Spanish is "es", as in "España", not "sp"
@HumbertoRincon3 жыл бұрын
Useful use cases, thanks Kyle
@bryanenid12283 жыл бұрын
What is the advantages of using this than using require() ? Just the async?
@avneet122843 жыл бұрын
This was truly great
@habibishuta48963 жыл бұрын
love your content man
@willyhorizont86722 жыл бұрын
thanks you're really helpful
@haoranxu44653 жыл бұрын
This is so useful☺️!
@eli-shulga3 жыл бұрын
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
@tanaseadrian83052 жыл бұрын
awesome tutorial
@sean98293 жыл бұрын
Wow. Didn’t know about this one. Thanks
@m0hammedimran3 жыл бұрын
I love your videos. But please increase the volume. I was wondering if my speaker was working
@Biersasam2 жыл бұрын
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 Жыл бұрын
yeah, what about that... probably it got cached, but is this something to avoid?
@stanislavmalyshev52093 жыл бұрын
Good job!
@khoaiviet74363 жыл бұрын
Thank you. This very helpful
@RadiGamer2 жыл бұрын
damn, that was useful! Thanks a lot man :D
@karolsyta17423 жыл бұрын
Can I use async/await with default import name as in translations example? Where to put try .. catch then?
@kirayatail3 жыл бұрын
Hey, I learned something today. Have a like!
@me_manish_prajapati3 жыл бұрын
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.
@kalokal58123 жыл бұрын
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)?
@Vipers9923 жыл бұрын
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.
@jhandgreat70793 жыл бұрын
Thanks bro!
@kappitain3 жыл бұрын
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).
@vhawkins82893 жыл бұрын
This is cool. 😎 Currently, are the files downloaded each time the code is run?
@hiroyukinumaguchi19843 жыл бұрын
Thank you!!
@Lahiru_Udana3 жыл бұрын
awesome. thanks
@lasithadulshan73573 жыл бұрын
Shot & Sweet
@sky787102 жыл бұрын
Can you explain that with using webpack jsnop bundles so that selection bundle dynamically. Please.
@muhamedkaric42473 жыл бұрын
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.
@igorswies59133 жыл бұрын
I think there is caching so that one file only gets imported once but I might be incorrect when dealing with dynamic imports
@franciscod59873 жыл бұрын
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_prajapati3 жыл бұрын
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 )
@CybercoderNaj3 жыл бұрын
Are there any use cases for dynamic importing in React or Vue?
@the_BetaDev3 жыл бұрын
Maybe in importing a component dynamically only in case you need to use it
@kirponomarenko3 жыл бұрын
Lazy loading. User scrolls page and only then component loads. Probably good for landings.
@annguyenhoangphu4513 жыл бұрын
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?
@pokefan27113 жыл бұрын
{default: User, printUser} Shit I didnt know this existed. I already used a lot of destructurings, but not this. Thanks!
@redwilliams18043 жыл бұрын
Please tell me why your into sounds like Nimbasa city from Pokemon Black/White? I love it!
@jenstornell3 жыл бұрын
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-mahmud59522 жыл бұрын
Thanks a lot
@naveenda20643 жыл бұрын
I heard about dynamic import is not able to do the treeshaking
@xAxtroz3 жыл бұрын
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.
@someoneelse81033 жыл бұрын
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?
@nightcoder5k3 жыл бұрын
Good stuff
@brycetwyman2 жыл бұрын
Does this process change at all if I wish to import async functions?
@madhavmadhusoodanan18773 жыл бұрын
Yaaayyyy i got in within the first 1k views I feel blessed :)
@trinhle72273 жыл бұрын
3:09 anyone can tell me how to do that. thanks
@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?
@mzaini303 жыл бұрын
Set up your project as ESM. Add "type": "module" in package.json
@shaikshavalisyed20123 жыл бұрын
One of the best features of js.
@yewyewxd2 жыл бұрын
does async works in forEach? I thought it only works in for loop
@7heMech6 ай бұрын
Thanks.
@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 Жыл бұрын
Nice!
@DuyTran-ss4lu3 жыл бұрын
Awesome!
@the_BetaDev3 жыл бұрын
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?