11. Mọi thứ cần biết về Client Component Next.js

Поділитися
Вставка
  • Опубліковано 2 гру 2024

КОМЕНТАРІ • 26

  • @duocdev
    @duocdev  6 місяців тому

    🎥 Mình đã có khóa Next.js Super trả phí: duthanhduoc.com/courses/nextjs-super
    📕 Đây là link github khóa học Next.js Free, các bạn không cần phải submit email nữa: github.com/duthanhduoc/nextjs-free

  • @LinhĐình-f4h
    @LinhĐình-f4h 25 днів тому +1

    Bài này quá hay anh ơi, kiến thức quá chuẩn. +1 respect.
    À giải thích cho bạn nào thắc mắc sao code frontend mà vẫn có client và server nhé. Theo mình hiểu, server chính là nơi chứa mã nguồn của trang web (cụ thể là chứa các file html, js, css, ... của các bạn) còn client chính là cái trình duyệt mà user dùng (có thể là điện thoại, máy tính của họ).
    Bản chất là khi user vào trang web thì trình duyệt sẽ tải các file html, js, css từ nơi lưu trữ (server) xuống rồi render ra giao diện.

    • @vanbui-ci5gv
      @vanbui-ci5gv 20 днів тому

      thế cái server chứa các câu lệnh db cũng như xử lý req nó cũng là server nhưng nó khác gì với server bạn nói vậy

    • @LinhĐình-f4h
      @LinhĐình-f4h 20 днів тому +1

      Về bản chất thì mình thấy nó giống nhau thôi bạn, chẳng qua này là về system design, người ta muốn chia ra thành 1 server frontend (chứa các mã nguồn chuyên xử lý về giao diện) và 1 server backend xử lý logic.
      Bạn hoàn toàn có thể gộp chúng lại thành 1, điển hình là mô hình MVC.
      Hay bạn cũng có thể code giao hiện ở server backend rồi trả về html, css như thường. và ngược lại. Nhưng làm như vậy sẽ khiến source code bị rối và khó maintan và mở rộng

    • @vanbui-ci5gv
      @vanbui-ci5gv 20 днів тому

      @ à nghĩa là có 2 cách 1 là backend viết giao diện r trả về luôn như dùng hbs. 2 là viết giao diện ở next rồi gọi tới server logic

    • @LinhĐình-f4h
      @LinhĐình-f4h 19 днів тому

      @@vanbui-ci5gv đúng rồi nhé bạn, trong thực thế không chỉ có 2 loại này, còn có thể scale lên thành 3,4,... nhiều server khác, mỗi server sẽ có nhiệm vụ riêng của nó, các server sẽ giao tiếp với nhau qua api,...

  • @linhpksw
    @linhpksw 7 місяців тому

    Rất hay anh nhé! Lúc đọc docs còn mù mờ thì xem vid a hiểu rõ luôn. Cảm ơn anh rất nhiều

  • @iamnguyenhoanganh
    @iamnguyenhoanganh 8 місяців тому

    bài này hay anh ơi :v ra nhiều video hơn anh nhé

  • @tuyentrancong3646
    @tuyentrancong3646 8 місяців тому

    Hay quá anh ơi 🥰

  • @hungha9991
    @hungha9991 8 місяців тому +1

    Hay quá anh ơi, khóa học anh quá tuyệt vời

  • @tuananhday126
    @tuananhday126 23 дні тому

    khi nào nên dùng client cpn và server cpn vậy anh

    • @duocdev
      @duocdev  23 дні тому

      Dùng server component khi có thể, nó sẽ giúp giảm js bundle xuống client, cũng như tốt cho seo. Còn dùng client component khi component yêu càu tương tác như event handler, các hook như useEffect, usestate…
      Ngoài ra nếu page không public ra ngoài, không yêu cầu seo như page quản lý thì dùng client component cũng k sao

  • @dwchau.254
    @dwchau.254 6 місяців тому

    anh ơi cho e hỏi
    Cient component: phía server trả về html rỗng,… vậy thì server “ở đây” là gì ạ
    và phần Server component nữa ạ, cái render phía server, là mình có cần config gì không hay server nó tự trả về cho mình ạ?

    • @duocdev
      @duocdev  6 місяців тому +1

      Server ở đây là server được nextjs tạo ra dựa trên nodejs nhé. Server component thì em cứ xem các video tiếp đi rồi sẽ hiểu

  • @DuongHoang-ty5rq
    @DuongHoang-ty5rq 8 місяців тому

    mong anh ra them nhieu video hay

    • @duocdev
      @duocdev  8 місяців тому

      Okie em, mấy hôm nay hơi bận nên ra ít. Mai cố gắng quay nhiều hơn :v

    • @vannghia512
      @vannghia512 8 місяців тому

      Cái đoạn mà trình duyệt render client component 1 lần nữa gọi là quá trình hydrate đúng k a

    • @duocdev
      @duocdev  8 місяців тому +1

      @@vannghia512 đúng r em

  • @HuyLe-mj2rj
    @HuyLe-mj2rj 6 місяців тому

    đoạn cuối anh config thì điều anh muốn làm ở đây là gì v anh em chưa hiểu lắm mong a giải đáp tks a. (logging : fetch)

    • @duocdev
      @duocdev  6 місяців тому

      Khi ở chế độ dev, các em gọi fetch api thì nó sẽ log ra terminal cho em biết cái nào cache, cái nào không cache
      chi tiết
      nextjs.org/docs/app/api-reference/next-config-js/logging

  • @quannguyenviet643
    @quannguyenviet643 6 місяців тому

    anh cho em hỏi cái sever mà mình nhắc tới ở đây là cái sever của phần UI khác hoàn toàn với sever ở phần back-end (cái kết nối với database) phải không ạ

    • @duocdev
      @duocdev  6 місяців тому

      Đúng rồi em nhé. Giống như em code react thì em cũng phải cần 1 cái server backend kết nối db để trả data về render lên UI vậy đó

  • @vuchien7812
    @vuchien7812 8 місяців тому

    Bạn cho mình xin thông tin extension, khi build thì sẽ hiển thị trên browser mà bạn có đề cập trong video với nhé

    • @duocdev
      @duocdev  8 місяців тому +1

      Có mỗi react dev tool thôi bạn

  • @NguyenMinh-sf8fn
    @NguyenMinh-sf8fn 7 місяців тому

    anh ơi sự khác nhau của file .ts và .tsx là gì ạ, em viết .ts thay cho .tsx được không anh

    • @duocdev
      @duocdev  7 місяців тому

      Được. Nhưng đôi khi các editor như vs code sẽ không highlight code đúng. Vậy nên tốt nhất nếu em đang dùng cú pháp jsx trong file thì nên đặt là .tsx, không thì cứ .ts