arkts组件SideBarContainer :让侧边栏像呼吸一样自然

SideBarContainer 是 ArkTS 中专门处理「侧边栏+内容区」布局的容器组件,就像给应用装了一个智能抽屉------需要时滑出,不需要时自动隐藏。


核心设计

不同于传统布局的「固定占位」,SideBarContainer 通过空间智能分配实现三种形态的无缝切换:

  • · Embed模式:侧边栏与内容区共享空间,像书本的左右页
  • · Overlay模式:侧边栏悬浮覆盖,类似抽屉的推拉效果
  • · AUTO模式:根据容器尺寸自动选择最优方案

结构约束:2个子组件的精密舞蹈

SideBarContainer 对子组件有严格的「双人舞」规则:

子组件位置 角色定义 异常处理
第1个子组件 侧边栏(导航菜单) 超过2个时仅显示前两个
第2个子组件 内容区(主显示区域) 超过2个时仅显示前两个

特殊场景:当只有1个子组件时,侧边栏独占显示,内容区保持空白

三态切换的智能逻辑

Embed模式:空间共享的艺术

当容器宽度 ≥ minSideBarWidth + minContentWidth 时生效,侧边栏与内容区像拼图般严丝合缝。此时调整侧边栏宽度会实时挤压内容区空间,形成动态布局效果。

Overlay模式:悬浮层的优雅

侧边栏以蒙层形式出现,不占用主内容空间。适合小屏设备或需要聚焦内容的场景,配合半透明背景可营造层次感。

AUTO模式:自适应的智慧

API 10+ 引入的智能模式,以600vp为断点自动切换 Embed/Overlay。就像给组件装了一个「环境感知器」,能根据容器尺寸自动选择最优展示方案。

关键属性

尺寸控制体系

sideBarWidth。默认值240vp,支持动态调整(API 18+双向绑定)
minContentWidth。内容区最小360vp,保障核心内容不被压缩

交互控制开关

showControlButton默认true,可自定义图标样式

autoHide拖拽到最小宽度时自动隐藏

代码

复制代码
@Entry
@Component
struct SmartSideBar {
  @State isShow: boolean = true
  
  build() {
    SideBarContainer(SideBarContainerType.AUTO) {
      // 侧边栏:导航菜单
      Column() {
        Text('文档').fontSize(16).padding(12)
        Text('设置').fontSize(16).padding(12)
        Text('账户').fontSize(16).padding(12)
      }
      .backgroundColor('#F5F5F5')
      .width('200vp')
      
      // 内容区:主显示区域
      Column() {
        Text('内容区域')
          .fontSize(24)
          .fontWeight(FontWeight.Bold)
      }
      .padding(20)
    }
    .sideBarWidth('240vp')
    .minContentWidth('360vp')
    .showSideBar(this.isShow)
    .onChange((show: boolean) => {
      this.isShow = show
    })
  }
}
相关推荐
递归40416 小时前
ofdkit-harmony 0.2.0 发布:鸿蒙原生 OFD 阅读库,已上架 ohpm
开源·harmonyos·arkts·ofd·ohpm
大雷神2 天前
HarmonyOS APP<<古今职鉴定>>开源教程第26篇:【完整案例】职业性格测试开发
harmonyos·arkts·鸿蒙·古今职鉴
大师兄666810 天前
HarmonyOS 卡片 UI 三种玩法:普通卡片、动效卡片、Canvas 卡片
harmonyos·arkts·formkit·动效卡片·canvas卡片
UnicornDev22 天前
【HarmonyOS 6】底部悬浮导航的迷你栏适配(API23)
华为·harmonyos·arkts·鸿蒙
笔触狂放22 天前
【项目】基于ArkTS的老年人智能应用开发(1)
harmonyos·arkts·鸿蒙
UnicornDev24 天前
【HarmonyOS 6】底部悬浮导航的沉浸光感适配(API23)
华为·harmonyos·arkts·鸿蒙·鸿蒙系统
UnicornDev1 个月前
【HarmonyOS 6】设置页面 UI 设计
ui·华为·harmonyos·arkts·鸿蒙
UnicornDev1 个月前
【HarmonyOS 6】基于API23的底部悬浮导航
华为·harmonyos·arkts·鸿蒙·鸿蒙系统
积水成渊,蛟龙生焉1 个月前
鸿蒙手势处理篇(滑动冲突、基础手势、组合手势)
华为·arkts·鸿蒙·滑动冲突·手势冲突·基础手势·组合手势
纯爱掌门人1 个月前
聊聊 HarmonyOS 上的应用内通知授权弹窗
前端·harmonyos·arkts