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
    })
  }
}
相关推荐
笔触狂放40 分钟前
【项目】基于ArkTS的老年人智能应用开发(1)
harmonyos·arkts·鸿蒙
UnicornDev1 天前
【HarmonyOS 6】底部悬浮导航的沉浸光感适配(API23)
华为·harmonyos·arkts·鸿蒙·鸿蒙系统
UnicornDev6 天前
【HarmonyOS 6】设置页面 UI 设计
ui·华为·harmonyos·arkts·鸿蒙
UnicornDev9 天前
【HarmonyOS 6】基于API23的底部悬浮导航
华为·harmonyos·arkts·鸿蒙·鸿蒙系统
积水成渊,蛟龙生焉10 天前
鸿蒙手势处理篇(滑动冲突、基础手势、组合手势)
华为·arkts·鸿蒙·滑动冲突·手势冲突·基础手势·组合手势
纯爱掌门人10 天前
聊聊 HarmonyOS 上的应用内通知授权弹窗
前端·harmonyos·arkts
UnicornDev12 天前
【HarmonyOS 6】练习记录页面 UI 设计
ui·华为·harmonyos·arkts·鸿蒙
哈__13 天前
新手入门harmonyOS开发:手把手教你用ArkTS实现一个天气应用
harmonyos·arkts
积水成渊,蛟龙生焉14 天前
鸿蒙装饰器V2详解
华为·harmonyos·arkts·鸿蒙·ark
积水成渊,蛟龙生焉15 天前
鸿蒙通用事件(事件分发、事件拦截等)
华为·arkts·鸿蒙·事件分发·通用事件·事件拦截