Route là gì?
Trong Flutter, Route là một màn hình hoặc trang trong ứng dụng. Khi chúng ta nói về Route, chúng ta đang đề cập đến cách mà ứng dụng di chuyển giữa các màn hình và cách chúng ta xây dựng và quản lý các màn hình này.
Có hai loại Route phổ biến trong Flutter:
MaterialPageRoute
-
MaterialPageRoute là một loại route cơ bản trong Flutter, được sử dụng để điều hướng trực tiếp từ một màn hình này sang màn hình khác.
-
Khi sử dụng MaterialPageRoute, màn hình mới sẽ được đẩy lên (push) hoặc kéo xuống (pop) với hiệu ứng chuyển đổi mặc định.
Cách sử dụng:
Named Route
-
Named Route giúp bạn điều hướng bằng cách sử dụng tên của màn hình thay vì phải khởi tạo từng màn hình mỗi lần. Đây là cách tiếp cận tốt khi ứng dụng có nhiều màn hình và giúp bạn quản lý điều hướng dễ dàng hơn.
-
Với Named Route, bạn cần phải khai báo các route trong MaterialApp hoặc CupertinoApp.
Cách sử dụng:
Khai báo các Named Routes:
Điều hướng đến một Named Route:
CupertinoPageRoute
-
CupertinoPageRoute là một phiên bản route đặc trưng của iOS, có hiệu ứng chuyển màn hình giống như trên các ứng dụng iOS.
Cách sử dụng:
Navigation là gì?
Navigation trong Flutter là quá trình điều hướng giữa các màn hình trong ứng dụng. Điều này liên quan đến việc sử dụng Navigator để thực hiện các thao tác như mở, đóng, và thay đổi màn hình.
Navigator quản lý một stack (ngăn xếp) các Route và điều khiển việc hiển thị các màn hình (pages) trong ứng dụng.
Các hàm cơ bản trong Navigation:
-
Navigator.push(): Mở một màn hình mới và đẩy màn hình đó lên trên stack.
Navigator.pop(): Quay lại màn hình trước đó trong stack. Đây là cách bạn trở về màn hình trước khi sử dụng Navigator.push().
Navigator.pushNamed(): Mở màn hình theo tên route đã định nghĩa. Đây là cách điều hướng sử dụng các named routes thay vì phải tạo MaterialPageRoute mỗi lần.
Navigator.popUntil(): Quay lại một màn hình nào đó trong stack mà bạn chỉ định. Ví dụ, quay lại trang chủ từ bất kỳ đâu trong ứng dụng.
Navigator.pushReplacement(): Thay thế màn hình hiện tại với màn hình mới mà không giữ lại màn hình cũ trong stack.
Navigator.pushAndRemoveUntil(): Mở màn hình mới và xóa tất cả màn hình trước đó trong stack, chỉ giữ lại màn hình mới.
Navigation và State Management
Có thể truyền dữ liệu hoặc trạng thái giữa các màn hình bằng cách sử dụng Navigator.push() với arguments hoặc Navigator.pushNamed().
Trong màn hình nhận, có thể truy cập arguments như sau:
Ứng dụng vào project Note App
Mục tiêu : Tạo thêm màn hình chi tiết Note
Tạo screen Detail
Dùng push
để mở màn hình chi tiết
Kết quả :