Javascript Array and Object Cloning: Shallow or Deep?

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

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

  • @FuDiep
    @FuDiep 9 месяцев назад +18

    Babe wake up, the absolute GOAT came out with a new video

  • @TomAinsworth94
    @TomAinsworth94 9 месяцев назад +2

    This is great Jack, thanks a lot! I was mildly aware of deep vs shallow copies/clones but seeing the different use cases, and performance benchmarks is really helpful

  • @ElevateCode
    @ElevateCode 2 месяца назад

    Excellent video. Clear explanation, great examples, audio and video are very clear. Thank you so much for putting this together!

  • @OdradasMarch2027
    @OdradasMarch2027 9 месяцев назад +1

    This type content is very rare in RUclips. To validate your statement and teaching with real experiment where everything is clear cut like Black and White not gray.
    I love this approach of teaching.❤🧡💛💚💙💜

  • @JohnFarrellDev
    @JohnFarrellDev 9 месяцев назад +2

    I just learnt about structuredClone, thank you very much!
    Nice to remove a dependency.

  • @JohannPerezE
    @JohannPerezE 9 месяцев назад +2

    Please never stop ❤

  • @jensadria
    @jensadria 9 месяцев назад +5

    At 0:36 I thought I was watching the movie "Honey, I Shrunk the Software Developer"

  • @tanercoder1915
    @tanercoder1915 8 месяцев назад +1

    Your Illustratuons were amazing and to the point for those of us visual types 😊

  •  9 месяцев назад +1

    Great!! Best explanation ever!! If we wonder there's a risk changing the original values of array/object maybe there we need deep copy.

  • @victorlongon
    @victorlongon 9 месяцев назад +1

    great video Jack! I started using structuredClone quite a lot. I feel that is depends on the kind of applications you build to shallow vs deep copy.

  • @pov_stevo
    @pov_stevo 9 месяцев назад +2

    I just asked chatgpt this a day or two ago, you explained it a lot better. Thank you Jack

  • @Cahnisama
    @Cahnisama 9 месяцев назад +1

    I had to solve a bug the other day because I didn't understand I was doing a shallow copy with the spread, and unwittingly i was mutating the original object. This stuff is super important

  • @crowsec-software
    @crowsec-software 9 месяцев назад +1

    Great video I never actually gave it too much thought in js and was excited to see the test results. I typically just create new objects and use the spread operator syntax but structuredClone looks like it could be useful too.

  • @nillerbjj1
    @nillerbjj1 9 месяцев назад +1

    Thanks Jack, great video. 👍

  • @akashsharma4311
    @akashsharma4311 Месяц назад

    Thank you for explaining this ❤

  • @yogeshvanzara5553
    @yogeshvanzara5553 9 месяцев назад +2

    Back to back quality content ❤ .
    can you make on vedio on "this" if possible it's confusing with normal fuction and arrow function and lot more with this?.

  • @kettenbach
    @kettenbach 9 месяцев назад +13

    I wonder how many likes get missed. Often at the end of a video while I'm watching on my smart TV, it will show thumbnails of other videos. This is when we get reminded to like the video, but at that point you can't like it because pressing up no longer shows the thumbs, but only navigates to the thumbnail. Basically i had to go on my phone in the history and like the video. I wish RUclips could do better in this case.

    • @dave6012
      @dave6012 9 месяцев назад

      Me too man. Same thing. And if you back up to go like the video you can lose your next video recommendation.

    • @AreyHawUstad
      @AreyHawUstad 9 месяцев назад +1

      Like is not a big indicator for a viral video, it's the watch time. So if you're watching the full video you're already helping the creator more than liking it.

  • @andrewbrowne8498
    @andrewbrowne8498 9 месяцев назад

    I know you kept it to built-in methods, but a video about tools like immer would be really cool

  • @pw.70
    @pw.70 9 месяцев назад

    Wow! Amazing how the 'optimised' code written by the JS team is way slower than a double conversion!

  • @hartesgeld
    @hartesgeld 9 месяцев назад +2

    Jack Herrington is a legend. Simple as that.

  • @deatho0ne587
    @deatho0ne587 9 месяцев назад +1

    Shallow when you can, deep when you have to. If it is straight from the API you should do a deep with verification/modifications anyways.
    StructuredClone vs JSON.parse/stringfy is not only about performance and Dates. StructuredClone is Chrome 98 and 2022+ browsers roughly. This most likely does not matter for your personal projects, but need to think about it for Enterprise software. Also can target older versions of ES if needed in package.json.

  • @AmanBharti-ki1gs
    @AmanBharti-ki1gs 6 месяцев назад

    All cleared

  • @dog4ik
    @dog4ik 9 месяцев назад +6

    the fact that Json stringify Json parse "trick" not considered anti-pattern is so f'd up

    • @adambickford8720
      @adambickford8720 9 месяцев назад

      This is the community that uses switch(true){}.

    • @codesymphony
      @codesymphony 6 месяцев назад

      doesn't it also literally open you up to injection possibilities. json parse scares the hell out of me lol

  • @sterlo
    @sterlo 9 месяцев назад +2

    That's a lot of AI/bot comments 😂- thanks for the video. Really interesting to see that the newly implemented method is slower in this case.

  • @ParasmaniRai-mf1pu
    @ParasmaniRai-mf1pu Месяц назад

    so, we can have deep cloning using nested shallow cloning? Am I right? If not can someone clarify me? Thank you

  • @coolmind2476
    @coolmind2476 9 месяцев назад

    How about a simple recursive function for deep cloning? Just check if each item of an array is an array, if yes, make a recursive call, if not, Return spreaded ...item.
    Could you do a speed comparison as well?

    • @jherr
      @jherr  9 месяцев назад

      I could do that, but I know what the results will be. Any native methods (structuredClone or shallow clone) will blow the freaking doors off of logic running in JS.

    • @jherr
      @jherr  9 месяцев назад +2

      Ok, I was wrong, turns out it's faster. jsbenchmark.com/#eyJjYXNlcyI6W3siaWQiOiJDVlA1V1c0bzVDNjlYVktLNVBORHEiLCJjb2RlIjoiSlNPTi5wYXJzZShKU09OLnN0cmluZ2lmeShEQVRBKSk7IiwiZGVwZW5kZW5jaWVzIjpbXSwibmFtZSI6IkpTT04uc3RyaW5naWZ5In0seyJpZCI6IlBoSVVNTW9yLXZNVHhzcGt6Q3ZZbyIsImNvZGUiOiJzdHJ1Y3R1cmVkQ2xvbmUoREFUQSk7IiwibmFtZSI6IlN0cnVjdHVyZWRDbG9uZSIsImRlcGVuZGVuY2llcyI6W119LHsiaWQiOiJMY3hFanVLRzRhWl90LTZ3bjNWU3kiLCJjb2RlIjoiZnVuY3Rpb24gY2xvbmVPYmplY3Qob2JqKSB7XG4gIGlmKEFycmF5LmlzQXJyYXkob2JqKSkge1xuICAgIHJldHVybiBvYmoubWFwKGNsb25lT2JqZWN0KTtcbiAgfSBlbHNlIGlmKHR5cGVvZiBvYmogPT09ICdvYmplY3QnKSB7XG4gICAgcmV0dXJuIE9iamVjdC5lbnRyaWVzKG9iaikucmVkdWNlKChhY2MsIFtrZXksIHZhbHVlXSkgPT4ge1xuICAgICAgYWNjW2tleV0gPSBjbG9uZU9iamVjdCh2YWx1ZSk7XG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9KTtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gb2JqO1xuICB9XG59XG5jbG9uZU9iamVjdChEQVRBKSIsIm5hbWUiOiJDb3B5IHdpdGggSlMiLCJkZXBlbmRlbmNpZXMiOltdfV0sImNvbmZpZyI6eyJuYW1lIjoiRGVlcCBDbG9uZSB3aXRoIEpTIiwicGFyYWxsZWwiOnRydWUsImdsb2JhbFRlc3RDb25maWciOnsiZGVwZW5kZW5jaWVzIjpbXX0sImRhdGFDb2RlIjoicmV0dXJuIG5ldyBBcnJheSgxMDAwMCkuZmlsbCgwKS5tYXAoKCkgPT4gKFxuICB7IGE6IFt7IHA6IDEgfSx7IHA6IDIgfSx7IHA6IDQgfV0sIGI6IFt7IHA6IFsxLDIsM10gfSw1LDZdLCBjOiBbNyw4LDldIH1cbikpOyJ9fQ

  • @karwanrasul7450
    @karwanrasul7450 9 месяцев назад +1

    very usefull

  • @msahu2595
    @msahu2595 9 месяцев назад +1

  • @muhammadmuzammil7592
    @muhammadmuzammil7592 8 месяцев назад

    Great 🎉

  • @voidmind
    @voidmind 8 месяцев назад

    All the functions I write are pure functions, so I have some deep copying happening all over my code, and honestly the performance penalty is not noticeable. You'd have to use pretty huge data structures to notice it.

  • @noahwinslow3252
    @noahwinslow3252 9 месяцев назад

    Is lodash just bloat at this point? Every time my coworker uses lodash I feel like I could write the method myself with less work, more clarity and more efficient code. And I also flash back to the article "Why you probably don't need lodash"

    • @odra873
      @odra873 9 месяцев назад +1

      I still use lodash, why should I implement something that already covers all edge cases, is known in the team and tested?
      you write tests for your own implementation, everyone knows that you added it and not a second person add the same function somewhere else? (We have over 100 devs in our code base)
      And you sure you’re more efficient? Does it even make a difference if you don’t use it at 100k dataset size?
      Bunch of points to consider just to have 3 lines of code nicer which you look at maybe once a year

    • @jherr
      @jherr  9 месяцев назад

      I don't think it's either/or. For example I'd rather see someone use `array.filter` in it's native form as opposed to `_.filter`. And a lot of Lodash covers these common cases that are now covered by ES6. And ES6 was released eight years ago. Having a look at the Lodash docs I'd say that roughly 60% of these methods are either directly replaced by ES6, or an ES6 one-liner. But for those 40% I might use Lodash for that.

    • @noahwinslow3252
      @noahwinslow3252 9 месяцев назад

      @@jherr this 100% there's certainly good lodash functions but when I see people reaching for _.filter or _.sort I'm like... You know this exists in JS now, right? My page bundle thanks you 😂

    • @borisjoffe
      @borisjoffe 9 месяцев назад

      lodash can be really fast

  • @Ga2-20
    @Ga2-20 9 месяцев назад

    Hey Jack!
    What is your best JS framework and why? Do you even have something like best framework? 😅
    I mean I want to be good at one or two that are enough to build things fast efficiently and flexible on production. I see everywhere people are doing click bait videos why I don't yes this and that, and you shouldn't too 😂
    I really know that you have a lot of knowledge and great content, that's why I am asking 🙂
    God bless you!

    • @jherr
      @jherr  9 месяцев назад +1

      Thanks. And no, I don't think there is "one size fits all" best framework. You could have a content heavy application with only small areas of client side functionality (i.e. islands). For that I'd use Astro or HTMX. You could have a very heavy client side app with no requirements for SSR and for that I might look at something like React in a SPA mode on Vite, or Solid.
      If I had to pick two I'd probably go with NextJS and Astro. I think you effectively pick up SPA almost for free with NextJS. All you need to learn is a router like React Router or Tanstack Router.

  • @FrontendNerd-lg3oh
    @FrontendNerd-lg3oh 9 месяцев назад +1

    more Javascript tutorials

  • @abhishek_k7
    @abhishek_k7 8 месяцев назад

    I see that you are a Godzilla/Gojira fan too!

  • @keithjohnson6510
    @keithjohnson6510 9 месяцев назад

    Seems odd that structuredClone is slower. I assume because JSON is used so much in JS, it's been optimised to the hilt. So looks like structuredClone could do with some love here.
    I had a need to send JS Objects over a websocket connection, JSON was of course too limited, I needed Dates & Buffers etc. So just created a simple ObjectToBinary, & BinaryToObject, later I thought, actually that's also handy for Cloning & comparing objects too. Would have been much nicer if Javascript had this feature built in, as of course with my code not been Native it's slower, but doesn't seem to be an issue for what I need it for, even running on mobile etc. ps. I did look at NPM for something similar but couldn't find anything at the time, eg. js-binary requires a schema, I just wanted to pass an object and convert to & from binary, with custom types too.

    • @jherr
      @jherr  9 месяцев назад

      Structured Clone is slower, yes. But it's also more compatible that JSON.parse(JSON.stringify()) and there is question of how much you are calling it. If you don't call it continuously then most likely in common use cases there won't be a noticable performance impact.

  • @virtual5754
    @virtual5754 9 месяцев назад +2

    I will take pineapple pepperoni pizza