【React】Ant Design社区扩展库之分割面板:react-resizable-panels

主角:react-resizable-panels
简介:来之Ant Design官方文档社区精选组件

1、效果

分割面板应用效果

2、环境

  • react-resizable-panels: ^2.0.16
  • next: 14.1.3
  • react: ^18

3、安装

# npm
npm install react-resizable-panels# yarn
yarn add react-resizable-panels# pnpm
pnpm add react-resizable-panels# bun
bun add react-resizable-panels

4、组件概述

  • PanelGroup: 布局容器
  • PanelResizeHandle: 分割线控件,无自带样式,使用classNamestyle属性自定义
  • Panel: 面板容器,其下可嵌套任何元素

5、基础用法

// file: app/test/page.tsx
"use client"import { Card } from "antd"// 引入基础组件
import { Panel, PanelGroup, PanelResizeHandle
} from "react-resizable-panels";// 给边线来点小样式
const PanelResizeHandleStyle = {outline: 'none',flex: '0 0 .25rem',justifyContent: 'stretch',alignItems: 'stretch',transition: 'background-color .2s linear',display: 'flex'
}const TestView = function () {return (<><PanelGroup direction="horizontal"><Panel><Card>Card Panel 1</Card></Panel><PanelResizeHandle style={PanelResizeHandleStyle} /><Panel><Card>Card Panel 1</Card></Panel></PanelGroup>;</>)
}export default TestView;

6、组件Props

6.1、PanelGroup Props

属性类型描述
autoSaveId?string用于自动保存组排列的唯一 ID localStorage
childrenReactNode任意 React 元素
className?string附加到根元素的类名
direction“horizontal”“vertical”
id?string组ID;回落到useId未提供时
onLayout?(sizes: number[]) => void当组布局更改时调用
storage?PanelGroupStorage自定义存储API;默认为localStorage
style?CSSProperties附加到根元素的 CSS 样式
tagName?string = “div”根元素的 HTML 元素标签名称

①:存储API必须定义以下同步方法:

  • getItem: (name:string) => string
  • setItem: (name: string, value: string) => void

用于手动调整大小的命令式 API:

方法描述
getId(): string获取面板组的 ID
getLayout(): number[]获取面板组的当前布局( [1 - 100, ...])。
setLayout(layout: number[])将面板组大小调整为指定布局( [1 - 100, ...])

6.2、Panel Props

属性类型描述
childrenReactNode任意 React 元素
className?string附加到根元素的类名
collapsedSize?number=0面板应折叠至此尺寸
collapsible?boolean=false当调整大小超出其范围时,面板应该折叠minSize
defaultSize?number面板的初始大小(1-100之间的数值)
id?string面板 ID(组内唯一);回落到useId未提供时
maxSize?number = 100面板最大允许尺寸(1-100之间的数值);默认为100
minSize?number = 10面板最小允许尺寸(1-100之间的数值);默认为10
onCollapse?() => void面板折叠时调用
onExpand?() => void面板展开时调用
onResize?(size: number) => void调整面板大小时调用;size参数是 1-100 之间的数值。1
order?number小组内小组的顺序;对于具有条件渲染面板的组来说是必需的
style?CSSProperties附加到根元素的 CSS 样式
tagName?string = “div”根元素的 HTML 元素标签名称

6.3、PanelResizeHandle Props

属性类型描述
children?ReactNode自定义拖动UI;可以是任意 React 元素
className?string附加到根元素的类名
hitAreaMargins?{ coarse: number = 15; fine: number = 5; }在确定可调整大小的手柄点击检测时允许这么多余量
disabled?boolean禁用拖动手柄
id?string调整句柄 ID 的大小(组内唯一);回落到useId未提供时
onDragging?(isDragging: boolean) => void当组布局更改时调用
style?CSSProperties附加到根元素的 CSS 样式
tagName?string = “div”根元素的 HTML 元素标签名称

7、持久布局与 SSR 结合使用

默认情况下,该库用于localStorage保留布局。对于服务器渲染,当默认布局(在服务器上渲染)替换为持久布局(在 中localStorage)时,这可能会导致闪烁。
避免这种闪烁的方法是使用 cookie 来持久化布局,如下所示:

服务器组件

import ResizablePanels from "@/app/ResizablePanels";
import { cookies } from "next/headers";export function ServerComponent() {const layout = cookies().get("react-resizable-panels:layout");let defaultLayout;if (layout) {defaultLayout = JSON.parse(layout.value);}return <ClientComponent defaultLayout={defaultLayout} />;
}

客户端组件

"use client";import { Panel, PanelGroup, PanelResizeHandle } from "react-resizable-panels";export function ClientComponent({defaultLayout = [33, 67],
}: {defaultLayout: number[] | undefined;
}) {const onLayout = (sizes: number[]) => {document.cookie = `react-resizable-panels:layout=${JSON.stringify(sizes)}`;};return (<PanelGroup direction="horizontal" onLayout={onLayout}><Panel defaultSize={defaultLayout[0]}>{/* ... */}</Panel><PanelResizeHandle className="w-2 bg-blue-800" /><Panel defaultSize={defaultLayout[1]}>{/* ... */}</Panel></PanelGroup>);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/301878.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AI编程005/ 逆向生成mysql的建表语句

1/ 通过insert into 语句生成建表语句 有些时候我们能获取到表的insert语句&#xff0c;但是没有表结构。我们可以借助AI工具&#xff0c;让其逆向生成mysql的建表语句。 提示词如下&#xff1a; 根据下面的SQL语句&#xff0c;逆向生存mysql的建表语句&#xff0c;每个字段…

文心一言上线声音定制功能;通义千问开源模型;openAI又侵权?

文心一言上线定制专属声音功能 百度旗下 AI 聊天机器人文心一言上线新功能&#xff0c;用户录音一句话&#xff0c;即可定制声音。 使用这项功能需要使用文心一言 App。在创建智能体中&#xff0c;点击创建自己的声音&#xff0c;朗读系统提示的一句话&#xff0c;等候几秒钟时…

【大数据】大数据概论与Hadoop

目录 1.大数据概述 1.1.大数据的概念 1.2.大数据的应用场景 1.3.大数据的关键技术 1.4.大数据的计算模式 1.5.大数据和云计算的关系 1.6.物联网 2.Hadoop 2.1.核心架构 2.2.版本演进 2.3.生态圈的全量结构 1.大数据概述 1.1.大数据的概念 大数据即字面意思&#x…

网络工程师笔记18(关于网络的一些基本知识)

网络的分类 介绍计算机网络的基本概念&#xff0c;这一章最主要的内容是计算机网络的体系结构-ISO 开放系统互连参考模型&#xff0c;其中的基本概念&#xff0c;例如协议实体、协议数据单元&#xff0c;服务数据单元、面向连接的服务和无连接的服务、服务原语、服务访问点、相…

Vscode 中调试Django程序

调试介绍: ​​​​​​​Explore the debugger Debug/调试 可以让我们在特定的代码行上暂停程序的运行。当程序暂停时&#xff0c;我们可以查看变量的数值&#xff0c;在“Debug控制台”中运行代码&#xff0c;或利用“Debug”工具提供的其他功能。启动Debugger/调试器会自动…

迭代器模式

前言 迭代器模式就是分离了集合对象的遍历行为&#xff0c;抽象出一个迭代器类来负责&#xff0c;这样既可以做到不暴露集合的内部结构&#xff0c;又可让外部代码透明地访问集合内部的数据。 迭代器模式在访问数组、集合、列表等数据时&#xff0c;尤其是数据库数据操作时&am…

PSO-SVM,基于PSO粒子群算法优化SVM支持向量机回归预测(多输入单输出)-附代码

PSO-SVM是一种结合了粒子群优化&#xff08;Particle Swarm Optimization, PSO&#xff09;算法和支持向量机&#xff08;Support Vector Machine, SVM&#xff09;的方法&#xff0c;用于回归预测问题。下面我将解释PSO-SVM的原理&#xff1a; 1、支持向量机&#xff08;SVM&a…

系统架构评估_3.ATAM方法

架构权衡分析方法&#xff08;Architecture Tradeoff Analysis Method&#xff0c;ATAM&#xff09;是在SAAM的基础发展起来的&#xff0c;主要针对性能、实用性、安全性和可修改性&#xff0c;在系统开发之前&#xff0c;对这些质量属性进行评价和折中。 &#xff08;1&#x…

10倍提效!用ChatGPT编写系统功能文档。。。

系统功能文档是一种描述软件系统功能和操作方式的文档。它让开发团队、测试人员、项目管理者、客户和最终用户对系统行为有清晰、全面的了解。 通过ChatGPT&#xff0c;我们能让编写系统功能文档的效率提升10倍以上。 ​《Leetcode算法刷题宝典》一位阿里P8大佬总结的刷题笔记…

计算机网络-TCP连接建立阶段错误应对机制

错误现象 丢包 网络问题&#xff1a;网络不稳定可能导致丢包&#xff0c;例如信号弱或干扰强。带宽限制可能导致路由器或交换机丢弃包&#xff0c;尤其是在高流量时段。网络拥塞时&#xff0c;多个数据流竞争有限的资源&#xff0c;也可能导致丢包。缓冲区溢出&#xff1a;TC…

Astra深度相机在Ubuntu18.04系统下实现相机标定

问题&#xff1a; 当使用Astra相机的启动的指令启动相机后&#xff0c;使用rviz查看相机所发布的rgb数据时&#xff0c;在终端会出现如下的提示信息&#xff1a; Camera calibration file /home/car/.ros/camera_info/rgb_Astra_Orbbec.yaml not found. Camera calibration fil…

(学习日记)2024.04.11:UCOSIII第三十九节:软件定时器

写在前面&#xff1a; 由于时间的不足与学习的碎片化&#xff0c;写博客变得有些奢侈。 但是对于记录学习&#xff08;忘了以后能快速复习&#xff09;的渴望一天天变得强烈。 既然如此 不如以天为单位&#xff0c;以时间为顺序&#xff0c;仅仅将博客当做一个知识学习的目录&a…

nacos分布式程序开发实例

1.通过windows docker desktop 完成 nacos 的安装/启动/配置 &#xff08;1&#xff09;先安装docker desktop docker-toolbox-windows-docker-for-windows-stable安装包下载_开源镜像站-阿里云 &#xff08;2&#xff09;配置docker 国内镜像源 Docker 镜像加速 | 菜鸟教程…

携程旅行 abtest

声明: 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01;wx a15018601872 本文章…

Linux|从 STDIN 读取 Awk 输入

简介 在之前关于 Awk 工具的系列文章中&#xff0c;主要探讨了如何从文件中读取数据。但如果你希望从标准输入&#xff08;STDIN&#xff09;中读取数据&#xff0c;又该如何操作呢&#xff1f; 在本文中&#xff0c;将介绍几个示例&#xff0c;展示如何使用 Awk 来过滤其他命令…

WPF使用MVVM,将Image中的图片绑定到OpenCVSharp中的Mat类型

看了很多帖子&#xff0c;代码复制过去都是报错的&#xff0c;查看了OpenCVSharp.Extensions的底层&#xff0c;发现用法在WPF中已经进行了更改&#xff0c;原本需要从Mat->Bitmap->BitmapImage&#xff0c;简化成了Mat->BitmapSource这一个过程&#xff0c;所以这也是…

基于单片机水塔水位检测控制系统设计

**单片机设计介绍&#xff0c; 基于单片机水塔水位检测控制系统设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机水塔水位检测控制系统设计的主要目标是实现水塔水位的自动监测与控制&#xff0c;确保水塔内的水位始…

J基于微信小程序的电影订票、电影购票小程序

文章目录 1 **摘 要**2 技术简介**3 系统功能设计****第4章 系统设计****4.1系统结构设计** 第5章 系统实现**5.1管理员服务端功能模块**5.2用户客户端功能模块 结 论6 推荐阅读7 源码获取&#xff1a; 1 摘 要 本文从管理员、用户的功能要求出发&#xff0c;电影订票系统小程…

一文读懂RISC-V与ARM

RISC-V和ARM是近年来备受关注的两种处理器架构。RISC-V是一种基于精简指令集计算(RISC)原理的开源指令集架构(ISA)&#xff0c;而ARM是一种专有ISA&#xff0c;由于其长期存在于嵌入式系统和移动设备中&#xff0c;已成为嵌入式系统和移动设备的主导选择。市场以及多年积累的信…

ElasticSearch中的分片,副本分别表示什么

在大多数环境中&#xff0c;每个节点都在单独的盒子或虚拟机上运行。 索引 - 在Elasticsearch中&#xff0c;索引是文档的集合。分片 -因为Elasticsearch是一个分布式搜索引擎&#xff0c;所以索引通常被分割成分布在多个节点上的被称为分片的元素。 一个索引被分解成碎片以便…