Chuyển tới nội dung chính
Phiên bản: 1.11.0
import { Sheet } from "zmp-ui";

Dùng để hiển thị thông tin bổ sung hoặc để người dùng thực hiện một số hành động phụ liên quan đến nội dung chính trên màn hình, tiếp tục sử dụng tiếp một tính năng của ứng dụng

Ví dụ

Bảng thuộc tính

SheetProps

NameTypeDefaultDescription
afterClose() => void

Callback được gọi sau khi sheet được đóng.

autoHeightbooleanfalse

Tự động điều chỉnh chiều cao của sheet theo nội dung.

childrenReact.ReactNode

Nội dung cần được hiển thị bên trong bottom sheet.

contentRefReact.MutableRefObject

Tham chiếu đến phần tử chứa nội dung của sheet trên cây DOM.

defaultSnapPointnumber

Snap point mặc định khi mở sheet. Giá trị được truyền vào dưới dạng index trong mảng snapPoints.

handlerbooleantrue

Sheet handler là một thanh màu đen nằm ngang ở phía trên cùng của sheet, dùng để kéo sheet lên hoặc xuống.

heightstring | number

Chiều cao của sheet. Nếu không thiết lập, sheet sẽ có chiều cao mặc định theo nội dung.

maskbooleantrue

Mask là một lớp overlay màu xám được phủ lên các thành phần bên dưới hộp thoại của picker, ngăn không cho người dùng tương tác với các nội dung đó và tập trung vào hộp thoại được mở.

maskClassNamestring

CSS class của mask.

maskClosablebooleantrue

Cho phép tự động đóng sheet khi click vào mask.

maskStyleReact.CSSProperties

Inline style của mask.

modalClassNamestring

CSS class của sheet.

modalStyleReact.CSSProperties

Inline style của sheet.

snapPointsnumber[] | ((props: { sheetModalHeight: number }) => number[])

Khai báo các snap points của sheet. Snap points là các điểm mà tại đó sheet sẽ dừng lại khi người dùng kéo lên hoặc xuống. Số lượng snap points là không giới hạn.

Mỗi snap point có giá trị từ 0 với 1 với 0 là khi sheet hoàn toàn mở và 1 là khi sheet hoàn toàn đóng. Bên cạnh truyền snap point dưới dạng một số cố định, các hàm để tính toán các snap points dựa trên chiều cao của sheet cũng có thể được truyền vào.

Không giới hạn số lượng snap points.

swipeToClosebooleantrue

Cho phép người dùng đóng sheet bằng thao tác vuốt xuống trên nội dung của sheet.

titlestring

Tiêu đề của sheet, hiển thị ở phía trên cùng.

unmountOnClosebooleanfalse

Mặc định khi người dùng đóng sheet, giao diện của nó vẫn còn được render trong DOM và chỉ bị ẩn đi. Thiết lập này cho phép gỡ sheet ra khỏi cây DOM hoàn toàn sau khi đóng.

Thiết lập này có thể giúp giảm bộ nhớ được sử dụng trong trường hợp sheet có nội dung lớn. Tuy nhiên, khi sheet được mở lại, tất cả nội dung sẽ phải render lại từ đầu.

visiblebooleanfalse

Trạng thái mở hay đóng của sheet.

Cần phải sử dụng cùng với onClose để cập nhật lại giá trị của visible khi người dùng yêu cầu đóng sheet, nếu không sheet sẽ không đóng được.

widthstring | number

Chiều rộng của sheet. Nếu không thiết lập, sheet sẽ có chiều rộng mặc định là toàn màn hình.

zIndexnumber

Độ sâu của sheet, dùng để xác định thứ tự hiển thị của sheet đối với các phần tử lơ lửng khác nếu có.

onClose(e: React.SyntheticEvent) => void

Callback được gọi khi người dùng yêu cầu đóng sheet. Cần phải cập nhật lại giá trị của visible nếu có truyền vào trong callback này.

onSnap(snapPoint: number) => void

Callback được gọi khi sheet được snap đến một snap point mới.

SheetContentProps

NameTypeDefaultDescription
ariaIdstring
childrenReact.ReactNode

Nội dung cần được hiển thị bên trong bottom sheet.

modalRefReact.MutableRefObject

Tham chiếu đến phần tử chứa nội dung của sheet trên cây DOM.

titlestring

Tiêu đề của sheet, hiển thị ở phía trên cùng.

onMouseDownReact.MouseEventHandler
onMouseUpReact.MouseEventHandler
onVisibleChanged(visible: boolean) => void

Callback được gọi khi trạng thái hiển thị của sheet thay đổi.

SheetRef

NameTypeDefaultDescription
sheetHTMLDivElement

Trỏ đến phần tử của sheet trên cây DOM

snapTo(snapPoint: number) => void

Hàm dùng để snap đến một snap point đã khai báo. Xem thêm về snapPoints của Sheet.

miniapp-logo

Khám phá