Event loop trong javascript là gì?

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

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

  • @phananh8589
    @phananh8589 4 года назад +10

    một trong những video training rất chất lượng nhất, khâm phục kiến thức chắc chắn và khả năng diễn đạt gọn gàng của anh, rất mong ra anh "xuất bản" những video tương tự, các design pattern và kiến thức core nâng cao, luồng chạy... như vầy rất đáng xem. thank Anh!

  • @nguyenmanh8330
    @nguyenmanh8330 4 года назад +2

    Video thật bổ ích, khả năng kiến thức nền vững vcđ :V diễn đạt khá hay và rất Đà Nẵng

  • @nguyentrongtienk16_hcm
    @nguyentrongtienk16_hcm 2 года назад

    tuyệt vời, em đọc tài liệu hoa hết cả mắt vô đây nghe tí hiểu liền :>>>

  • @AnDinh144
    @AnDinh144 2 года назад

    Hồi trước hay ước có kênh nào dạy kiến thức kiểu này, bây giờ mới cơ duyên gặp được.
    Cảm ơn ông a nhiều.

  • @thanhbinhnguyen5943
    @thanhbinhnguyen5943 2 года назад

    Coi video của Phillip hơi ngấm rồi coi của anh nữa thấm nhuần kiến thức lun :3 Hay quá trời

  • @manhhungpham1294
    @manhhungpham1294 2 года назад

    Anh Dev truyền đạt dễ hiểu thật :)))
    Anh vừa làm IT vừa đá chân sang mảng RUclips rất hợp luôn.

  • @TrungNguyenVan-ln7bp
    @TrungNguyenVan-ln7bp 2 года назад +1

    Hôm trước mình đi pv gặp đúng câu này, hỏi "Event Loop là gì". Hôm đấy đứng hình =))). Cảm ơn bạn đã giải thích rất rõ ràng

  • @HauLe-sn5yh
    @HauLe-sn5yh 7 месяцев назад

    Kiến thức bạn chia sẻ rất hay. Cám ơn bạn.

  • @HoaNguyen-kn4ci
    @HoaNguyen-kn4ci 3 года назад

    Những video như này hay lắm a ạ. Mong a ra những video ntn. Cảm ơn a nhiều

  • @ThangTran-hi3es
    @ThangTran-hi3es 3 года назад +1

    Tuyệt vời, không những lý thuyết mà minh họa cũng như demo quá xuất sắc. Chúc bạn luôn khỏe mạnh để đóng góp những video chất lưọng này cho cộng đồng nhé !

  • @duoipham
    @duoipham 4 года назад +1

    Anh giảng siêu dễ hiểu luôn trời ơiiiiiii em mãi mà không hiểu nổi được phần này cho tới khi gặp được anh ạ :((((((( huhuhu cảm ơn anh nhiều ạ :((((((

  • @tonchoithethao9665
    @tonchoithethao9665 2 года назад

    Hay và rất dễ hiểu nha anh. Cám ơn anh đã chia sẽ kiến thức.

  • @timlanglo2144
    @timlanglo2144 4 года назад +1

    Video rất hay. Cảm ơn anh vì những kiến thức đã chia sẻ.

  • @nguyenchien5084
    @nguyenchien5084 2 года назад

    Hay !!!! rất dễ hiểu, luôn thích kiểu học có demo hình ảnh như thế này :))

  • @huongnguyenmanh8559
    @huongnguyenmanh8559 2 года назад

    cảm ơn ông Dev nhiều. Rất hay và cô đọng ạ !

  • @angtinh5078
    @angtinh5078 2 года назад

    Video tuyệt vời lắm ạ

  • @lebao9862
    @lebao9862 26 дней назад

    video bổ ích quá. Cảm ơn anh nhiều

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

    video rất chất lượng ạ

  • @duonghoai4795
    @duonghoai4795 3 года назад

    Rất bổ ích. cảm đã đóng góp cho cộng đồng

  • @minhoan7974
    @minhoan7974 Год назад

    Cảm ơn a ạ , video của a rất dễ hiểu ạ

  • @tungnguyen3551
    @tungnguyen3551 4 года назад +1

    Quá dễ hiểu, quá hay. Ra nhiều hơn clip JavaScript đi a. 😁👍

  • @TungNguyen-wt7vc
    @TungNguyen-wt7vc 3 года назад

    Cám ơn anh đã chia sẻ kiến thức, rất tường tận và dễ hiểu

  • @hieuduong2299
    @hieuduong2299 3 года назад

    Anh chia sẻ phần nào cũng rất dễ hiểu. Cứu cánh em mấy lần. Cảm ơn a ạ

  • @KhoaNguyen-bk2kv
    @KhoaNguyen-bk2kv 3 года назад

    Bài chia sẻ hay và chi tiết. Cảm ơn anh nhiều.

  • @konandev4278
    @konandev4278 2 года назад +4

    trước khi học lập trình mình từng nghe mọi nguời nói rằng nên học bằng tiếng anh, học bằng video hay tutorial của người nước ngoài để giỏi hơn vì họ biết nhiều hơn nhưng rồi sau khi mình thử học theo cả 2 phương pháp là học từ các tutorial của VN và nước ngoài thì mình nhận ra rằng người VN mình dạy theo kiểu kinh nghiệm thực tế và luôn đưa ra những trường hợp sát với thực tế nhất nên cảm thấy kiến thức rất gần gữi với mọi người còn bên nước ngoài thì họ dạy theo kiểu chuyên sâu, tức là họ sẽ giống như đào sâu thêm về các khái niệm logic của vấn đề chứ không có tính thực tế lắm, tất nhiên các khái niệm đó là cái mà chúng ta sẽ áp dụng vào thực tế nhưng việc rút ra kinh nghiệm từ thực tế còn đáng giá hơn nhiều so với việc biết và áp dụng kiến thức vào thực tế. Tóm lại VN dạy theo kinh nghiệm thực tế - Nước ngoài dạy theo kiến thức cốt lõi chuyên sâu. Cái nào cũng có điểm mạnh nên mọi nguời hãy học một cách thông thái chứ đửng nên so sánh nhé! Cảm ơn anh Dev vui tính vì video rất hữu ích này. have a good day.

    • @thanhnguyenduy78
      @thanhnguyenduy78 Год назад

      ruclips.net/video/8aGhZQkoFbQ/видео.html&ab_channel=JSConf nước ngoài dạy đây nhé. Ông dev cũng chỉ học theo và dạy thôi nhé, đừng nói là nước ngoài dạy không thực tế, hơn nữa nhiều người nước ngoài còn giảng dạy thú vị và đầu tư tâm huyết vào đó hơn nhiều

  • @phamthang6558
    @phamthang6558 2 года назад

    video hay lắm a ơi

  • @khoavo579
    @khoavo579 3 года назад

    anh lý giải rất sâu và chi tiết! thank anh

  • @phuongnammmo1969
    @phuongnammmo1969 5 лет назад

    Cảm ơn anh vì đã chia sẻ những kiến thức rất giá trị

  • @Zuong2003
    @Zuong2003 Год назад

    Đúng là idol của t, cám ơn anh

  • @vilyduytruong4885
    @vilyduytruong4885 3 года назад

    dễ hiểu quá, tks a nhìu

  • @ucthainguyen289
    @ucthainguyen289 2 года назад

    Hay quá!

  • @anhtuan-nguyen
    @anhtuan-nguyen 2 года назад

    8:30 - Event loop

  • @namhuy5426
    @namhuy5426 Год назад

    Quá hay ạ

  • @LegendsVN
    @LegendsVN Год назад

    Xem lại sau 1 năm vẫn thấy hay

  • @amanlearnscode
    @amanlearnscode 4 года назад +2

    Trong cái queue nó còn phân chia ra micro task queue và macro task queue nữa, ưu tiên micro task queue :D

    •  4 года назад +2

      Uh, ví dụ như Promise sẽ được ưu tiên hơn setTimeOut

  • @nhiennd
    @nhiennd 2 года назад

    Hay quá a ạ

  • @duythinho806
    @duythinho806 4 года назад +1

    cảm ơn a hay thật

  • @phanphan6136
    @phanphan6136 4 года назад +1

    Cảm ơn anh!

  • @SonNguyen-zc6je
    @SonNguyen-zc6je 4 года назад +1

    Hay vãi c anh ạ !!!!!!!!!!

  • @tamdhpyc177
    @tamdhpyc177 3 года назад

    hay qá
    😀

  • @HuyLe-zx8ko
    @HuyLe-zx8ko 3 года назад

    quá hay

  • @tuankiethuynhngoc6171
    @tuankiethuynhngoc6171 2 года назад

    Thank you sir

  • @huyvu8051yt
    @huyvu8051yt 3 года назад

    hay a

  • @chauminh1313
    @chauminh1313 4 года назад

    e nghĩ là cái này nâng cao nhưng devjs ai cũng nên hiểu nhỉ, vì coi xong bản thân thấy hiểu hơn về luồng chạy của thg js @@, tks a vì video bổ ích

    •  4 года назад

      Đúng rồi e, cái này dev js ai cũng nên biết

    • @chauminh1313
      @chauminh1313 4 года назад

      @ E mò mẫm thì ra dc cái keyword là thread pool, theo e hiểu thì nó chính là cái queue của video trên, e hiểu v k biết có đúng k ạ ?

    •  4 года назад

      @@chauminh1313 Không nha, thread pool là kiểu 1 cái pattern mà nó sẽ phân chia công việc cho các thread khác nhau. Còn cái queue trên thì nó chỉ là 1 cái lượng công việc đang xếp hàng để được thực thi thôi

  • @luongminhduy9373
    @luongminhduy9373 2 года назад

    Em đang bắt đầu học JS và rất thích những video của anh. Anh cho em hỏi anh xài theme vs code gì vậy ạ?

  • @tungtran3994
    @tungtran3994 2 года назад +1

    cái chỗ callback phút 9:55 cho mình hỏi là nó put callback vào callstack mà lúc này trên video là cái global excution context nó bị remove rồi, thì tại sao biến window vẫn truy cập được nhỉ?, hày là nếu mình truy xuất window trong callback thì thằng js engine nó sẽ giữ lại global context đó

    • @tungtran3994
      @tungtran3994 2 года назад

      Mình có câu hỏi này, khi thực hiện setTimeout, thì sau khi timer chạy xong thì callback được gọi, mà thằng event loop nó phải check xem callstack nó empty hay chưa, tức là lúc này global excution context nó đã pop off ra khỏi callstack rồi, thì nếu mà trong callback của setTimeout mình có truy xuất tới biến window.hello, và vẫn truy xuất bình thường vậy thì lúc này sẽ ra sao bạn. nếu GEC sẽ bị pop off thật và khởi tạo lại thì những biến trong GEC bị reset luôn rồi, hay là do thằng callback nó còn ref tới biến var hello = 'xxx'; nên GEC sẽ vẫn giữ lại?

    •  2 года назад

      Trong thằng settimeout thì nó tự mặc định this(context) là window, nếu muốn thay đổi con text thì mình sẽ phải bind cái cb đó á

    • @tungtran3994
      @tungtran3994 2 года назад

      @ tức là GEC sẽ vẫn được giữ lại ? hoặc bạn có link thông tin về chỗ này thì gửi mình với

    •  2 года назад

      Uh, đó là theo cách mình hiểu, mới search ra cái này, bạn tham khảo thử: www.javascripttutorial.net/javascript-execution-context/

  • @banhmisg-dev
    @banhmisg-dev 4 года назад +3

    :/ mấy kênh như này hay nhưng mà sợ một thời gian thì drop mất, hy vọng a ko drop =))

    • @congnamle3632
      @congnamle3632 3 года назад

      Làm để chửi những Vozer hỏi YTB Vn sao ko có Technical :) xem nặng thật sự dù nó là video mang tính học tập cực cao kkk

  • @SonNguyen-bp7pg
    @SonNguyen-bp7pg 5 лет назад +1

    may quá em đang học nodejs mà ko hiểu phần này

  • @thienngo2953
    @thienngo2953 2 года назад

    :( ra thêm video đi anhh

  • @james-rx8kw
    @james-rx8kw 2 года назад +1

    vậy thằng fetch khi gọi api thì nó cũng sẽ chạy vô thằng callstack -> webapi -> queue , rồi cuối cùng mới ra lại callstack hả anh hay chỉ có thằng setimteOut mới vào webAPIs ạ

    •  2 года назад +1

      Đúng r e

  • @ThienNguyen-su2sp
    @ThienNguyen-su2sp 3 года назад +2

    cho em hỏi với ạ Nếu anh đang scroll setTimeout bằng 0 thì trong khi anh scrool thì console nó vẫn chạy song song v ạ

    •  3 года назад

      Đúng r, nhưng ngay khi em dừng scroll lại thì nó sẽ lôi callback của set timeout ra chạy

    • @ThienNguyen-su2sp
      @ThienNguyen-su2sp 3 года назад

      vậy cái mà khi anh đang scroll nó chạy có phải hàm callback của setTimeout k ạ. Nếu phải thì tại sao nó không dừng lại để chạy mà ình còn có thể scroll đcuwocj ạ . Em cảm ơn anh nhiều ạ. Chúc anh sức khỏe nè

    • @datnguyennnx
      @datnguyennnx 3 года назад +1

      Callstack nhận vào scoll + cb. Cb trả về console.log sẽ block các hoạt động khác => chạy song song cb với scoll. Khi ông ngưng scoll thì trong callstack chỉ còn Cb chạy vòng for => sẽ block hết các stack khác ( theo mình hiểu là vậy).

    • @oanduyen5864
      @oanduyen5864 Год назад

      Chung thắc mắc, không biết anh đã giải được cái này chưa cho em xin đáp án với ạ

    • @nguyenxuantruong2867
      @nguyenxuantruong2867 Год назад

      Khi scroll => function được push vào call stack => vì là asynchorous nên webAPIs có setTimeout default khi ở webAPIs là timer(time) callback rồi đẩy cb xuống queue… Lặp đi lặp lại như vậy cho đến khi khi ngưng scroll thì cb được push lên call stack và thực hiện, lúc này log được gen rồi pop, gen rồi pop khiến các action khác bị block, vậy thui

  • @baobaostore
    @baobaostore 3 года назад

    *javascript chỉ có 1 luồng thì tại sao nodeJS có thể xử lý hàng nghìn request cùng lúc được anh? hay là nó xử lý từng request mội, xong cái này rồi mới tới cái kia?*

  • @anywhereloc2969
    @anywhereloc2969 3 года назад

    Này học ở đâu vậy a e muốn học sâu về js

  • @trangbui8283
    @trangbui8283 3 года назад

    @Ông dev cho hỏi Phần timer deplay của settimeOut nó xảy ra ở đâu và khi nào vậy a? Ở WebAPis hay ở queue a

    •  3 года назад +1

      Webapi nha e

  • @thanhbinhnguyen5943
    @thanhbinhnguyen5943 2 года назад

    I luv u :3

  • @campingstore123
    @campingstore123 3 года назад

    anh cho em hỏi câu này ạ, trong clip anh có nói là callback ở setTimeout được thực hiện ở call stack, thì như vậy theo em hiểu là câu lệnh setTimeout nào có delay time ngắn hơn sẽ được thực hiện trc, nhưng em có thử chạy bằng nodejs đoạn code gồm 2 câu lệnh
    setTimeout (() => { console.log (1)}, 1000)

    setTimeout (() => { fs.readFileSync('noidung.txt'); console.log (2)}, 999.999).
    Nếu nội dung file noidung.txt lớn 1 chút thì console.log(1) sẽ được thực hiện trc trong lần đầu tiên, những lần sau thì console.log(2) được thực hiện trc. k biết vấn đề này có gây ra vướng mắc trong thực tế k ạ. Em cảm ơn anh

    •  3 года назад +1

      Hmm, thực ra thời gian ngắn hơn, nhưng call sau, thì sự chênh lệch của timeout nó không bằng so với tần số của cpu xử lý, thì nó sẽ kiểu 0.0001ms đó nó lớn hơn cái tick của cpu, thì khi mà cái timeout thứ 2 đi vào thì cái 1 nó đã count đc 1 lúc rồi. Còn lần sau, vì file ko thay đổi, nên code được cached lại, nên khi nó đưa vào cái event list gần như là đồng thời(nhanh hơn cái chênh lệch giữa 2 timeout) thì khi đó nó chạy như e dự kiến. Hmm a nghĩ vậy thôi. Chứ ko chắc nữa, a ít khi gặp th này

    •  3 года назад

      Em thử đưa cái 999.999 lên trước xem

    • @campingstore123
      @campingstore123 3 года назад

      @ em cảm ơn anh, em hiểu rồi ạ

  • @buidu691
    @buidu691 2 года назад

    bản chất cái window.onscroll mà ko dùng setTimeout thì nó vẫn được đưa vào queue bình thường mà đúng ko anh, tại em nhớ nó là 1 events thì cũng bay vào queue ạ. E cảm ơn a

    •  2 года назад

      Đúng r e.

  • @khaihoannguyen9446
    @khaihoannguyen9446 2 года назад

    nghe giọng anh giống như xứ Quảng vậy a?

    •  2 года назад

      A quê gốc QN mà, lớn lên ở Đà Nẵng haha

    • @khaihoannguyen9446
      @khaihoannguyen9446 2 года назад

      @ e ở Đại Lộc đây =)). Mới đầu e nghe giọng anh thấy đã thấy nghi nghi rồi =))

  • @quangcao2997
    @quangcao2997 5 лет назад

    e cảm ơn, đúng lúc e không hiểu :(

    •  5 лет назад +1

      Rất vui vì giúp được em, còn gì ko hiểu thì cứ comment, a sẽ xem xét ra video để giúp :D

  • @atNguyen-sy3il
    @atNguyen-sy3il 2 года назад

    cái microtask với macrotask nó sẽ đưa vào queue như thế nào vậy anh, với lại micro nó có cần qua web apis không anh.

    •  2 года назад +1

      Đến web apis hay ko nó ko có micro hay macro nha e. Cái callback nó mới phân biệt micro và macro. Đưa vào queue là thằng web apis nó đưa vào sau khi nó thực thi xong.
      Khi ở trong callback queue thì nó mới phân biệt macro và micro. Rồi nó sẽ dựa vào cái event loop để bốc task nào.

    • @atNguyen-sy3il
      @atNguyen-sy3il 2 года назад

      @ Huhu, em mông lung quá, em có xem cái video về micro và macro của anh rồi, nhưng mà nó không hình minh họa nên cũng không hiểu lắm, giả sử trong queue có 5 task macro ở trước 1 task micro thì event loop làm sao đưa cái micro này chạy trước đc ạ. nếu có cách gì đó thì trong lúc này 5 cái task macro kia thì mình để nó ở đâu. em có xem 1 số tutorial thì họ bảo có 2 cái queue 1 cái cho microtask (microtask queue) và 1 cái callback queue, và cái callback trong microtask queue sẽ ưu tiên đưa vào call stack trước, thì em xem thấy dễ hiểu hơn nhưng không biết có đúng không. Hôm qua em đi pv thì ngta hỏi câu này, em nói cái khái niệm 2 queue thì họ bảo sai :((((( Anh cứu em với. ruclips.net/video/vhhx2tljbdY/видео.html

    • @atNguyen-sy3il
      @atNguyen-sy3il 2 года назад

      @ Em có xem cái video về micro macro của anh rồi. nhưng mà nó không có hình minh họa nên cũng hơi khó hiểu. VD như giờ mình có 5 cb macro xếp trước 1 cb micro thì làm sao để event loop đưa cái micro chạy trước vậy anh, rồi trong quá trình đưa cái micro lên chạy trước, thì 5 cái macro kia mình để nó ở đâu. Em có xem 1 số tutorial thì họ bảo có 2 queue, 1 queue cho cb của promises (microtask queue) và 1 cái callback queue. thì cb ở trong microtask queue sẽ được ưu tiên chạy trước, và miễn là trong microtask queue còn cb thì cb trong callback queue ko đc execute. Không biết cái này có đúng không. Hôm qua em trả lời pv theo kiểu 2 queue này thì ngta bảo chỉ có 1 queue thôi :(((. Anh cứu em với.

    •  2 года назад +1

      @@atNguyen-sy3il uh nó có 1 cái macro queue chính, bên cạnh đó có thêm cái microtask queue nữa. Có thể cách em diễn đạt nó không đúng ý họ hay sao đó.

    •  2 года назад +1

      @@atNguyen-sy3il javascript.info/event-loop

  • @minhhieple6483
    @minhhieple6483 4 года назад

    Anh cho em hỏi mấy câu ạ ?
    - Cách thức hoạt động của Event Loop trong môi trường Browser và Node.js có khác nhau không ạ ?
    - Em vừa xem 1 video của một anh Dev làm core team của Node.js
    ruclips.net/video/PNa9OMajw9w/видео.html
    đoạn đầu (1:10) anh ấy có nói rằng 95% những mô tả về vòng lặp sự kiện trên internet đều sai làm em khá hoang mang :v, mong anh giải thích thêm.

    •  4 года назад

      Minh Hiệp Lê nó như nhau nha, chỉ có điều việc handle mấy cái event bằng 2 th khác nhau, trên browser thì là web apis(do browser cung cấp) còn node thì nó là 1 module trong node.
      Còn về việc video này có đúng hay không thì đây là kiến thức của mình sau thời gian làm việc với node có được, nếu bạn cảm thấy không an toàn thì nên bỏ qua, và xem video của anh Dev kia, mình thoải mái mà :D

  • @vuinhtien6513
    @vuinhtien6513 2 года назад

    for (var i=0; i console.log(i),0);
    } bạn ơi, bạn có thể giúp mình 1 lần này thôi, mình ko diễn tả được là var và let trong này thì khi đưa vào webapi, thì cái i trong webAPI sẽ là giá trị hay vẫn là i,

    • @phungnguyen1154
      @phungnguyen1154 2 года назад

      Không phải là WEBAPI, mà đây là về hoisting, bạn nên nắm thêm khái niệm về nó, tại sao khi sài var trong for lại log ra max I

  • @ucvo6209
    @ucvo6209 3 года назад

    ông này nói chuyện kiểu nghênh nghênh v nhỉ