鸿蒙:侧边栏显示与隐藏

前言:

本篇博客侧边栏显示与隐藏是基于Stack、transition、animation实现应用侧边栏点击显示和左滑隐藏的效果。

我们还是老样子,跟着官方文档学习与实践,链接如下:

https://developer.huawei.com/consumer/cn/doc/architecture-guides/sidebar_slide-0000002308440974https://developer.huawei.com/consumer/cn/doc/architecture-guides/sidebar_slide-0000002308440974大致给大伙写一下实现流程:

1、定义变量【我使用的是V2装饰器,你使用V1也可以】:

复制代码
  leftTitle: string = "这是左侧边栏"
  rightTitle: string = "这是右侧边栏"
  @Local isShowLeftBuilder: boolean = false // 左侧侧边栏是否显示
  @Local isShowRightBuilder: boolean = false // 右侧侧边栏是否显示
  @Local screenWidthPx: number = 0 // 屏幕宽度

2、UI初始化前获取屏幕宽度:

复制代码
aboutToAppear(): void {
    this.screenWidthPx = display.getDefaultDisplaySync().width
  }

3、创建一个组件或自定义构建函数,用来装左侧或右侧的侧边栏组件:

复制代码
  @Builder
  theBarBuilder(title: string) {

    Column() {
      Text(title)
        .fontSize(30)
        .fontWeight(FontWeight.Bold)
        .padding(20)
      Text("点击阴影处关闭侧边栏")
    }
    .backgroundColor(Color.White)
    .justifyContent(FlexAlign.Center)
    .width("85%")
    .height("100%")
    .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM])
    .transition(TransitionEffect.opacity(0.8).animation({ duration: 300, curve: Curve.Smooth })
      .combine(TransitionEffect.translate({
        x: this.isShowLeftBuilder ? -this.screenWidthPx * 0.85 : this.screenWidthPx * 0.85
      })))
  }

4、整体页面布局:

复制代码
 Stack() {

      // 主页面
      Column({ space: 20 }) {
        Text("👏案例页面👍")
          .fontSize(30)
          .fontWeight(FontWeight.Bold)

        Button("点击我开启左侧边栏")
          .onClick(() => {
            this.isShowLeftBuilder = true
          })
        Text("1111111111111111111111111111111111111111111111111111111111111111111111111111111111")
        Button("点击我开启右侧边栏")
          .onClick(() => {
            this.isShowRightBuilder = true
          })
        Text("1111111111111111111111111111111111111111111111111111111111111111111111111111111111")
      }
      .justifyContent(FlexAlign.Center)
      .width("100%")
      .height("100%")

      // 遮罩层
      if (this.isShowLeftBuilder || this.isShowRightBuilder) {
        Column()
          .onClick(() => {
            this.isShowLeftBuilder = false
            this.isShowRightBuilder = false
          })
          .width("100%")
          .height("100%")
          .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM])
          .backgroundColor(Color.Black)
          .opacity(0.5)
      }
      // 侧边栏
      if (this.isShowLeftBuilder) {
        this.theBarBuilder(this.leftTitle)

      } else if (this.isShowRightBuilder) {
        this.theBarBuilder(this.rightTitle)
      }


    }
    .width("100%")
    .height("100%")
    .alignContent(this.isShowLeftBuilder ? Alignment.Start : Alignment.End)

5、Index.ets 完整代码:

复制代码
import { display } from '@kit.ArkUI'

@Entry
@ComponentV2
struct Index {
  leftTitle: string = "这是左侧边栏"
  rightTitle: string = "这是右侧边栏"
  @Local isShowLeftBuilder: boolean = false // 左侧侧边栏是否显示
  @Local isShowRightBuilder: boolean = false // 右侧侧边栏是否显示
  @Local screenWidthPx: number = 0 // 屏幕宽度

  aboutToAppear(): void {
    this.screenWidthPx = display.getDefaultDisplaySync().width
  }

  build() {
    Stack() {

      // 主页面
      Column({ space: 20 }) {
        Text("👏案例页面👍")
          .fontSize(30)
          .fontWeight(FontWeight.Bold)

        Button("点击我开启左侧边栏")
          .onClick(() => {
            this.isShowLeftBuilder = true
          })
        Text("1111111111111111111111111111111111111111111111111111111111111111111111111111111111")
        Button("点击我开启右侧边栏")
          .onClick(() => {
            this.isShowRightBuilder = true
          })
        Text("1111111111111111111111111111111111111111111111111111111111111111111111111111111111")
      }
      .justifyContent(FlexAlign.Center)
      .width("100%")
      .height("100%")

      // 遮罩层
      if (this.isShowLeftBuilder || this.isShowRightBuilder) {
        Column()
          .onClick(() => {
            this.isShowLeftBuilder = false
            this.isShowRightBuilder = false
          })
          .width("100%")
          .height("100%")
          .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM])
          .backgroundColor(Color.Black)
          .opacity(0.5)
      }
      // 侧边栏
      if (this.isShowLeftBuilder) {
        this.theBarBuilder(this.leftTitle)

      } else if (this.isShowRightBuilder) {
        this.theBarBuilder(this.rightTitle)
      }


    }
    .width("100%")
    .height("100%")
    .alignContent(this.isShowLeftBuilder ? Alignment.Start : Alignment.End)
  }

  @Builder
  theBarBuilder(title: string) {

    Column() {
      Text(title)
        .fontSize(30)
        .fontWeight(FontWeight.Bold)
        .padding(20)
      Text("点击阴影处关闭侧边栏")
    }
    .backgroundColor(Color.White)
    .justifyContent(FlexAlign.Center)
    .width("85%")
    .height("100%")
    .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM])
    .transition(TransitionEffect.opacity(0.8).animation({ duration: 300, curve: Curve.Smooth })
      .combine(TransitionEffect.translate({
        x: this.isShowLeftBuilder ? -this.screenWidthPx * 0.85 : this.screenWidthPx * 0.85
      })))
  }
}

练手项目效果图:

如果觉得有帮助,欢迎点赞、收藏或关注

相关推荐
IntMainJhy3 小时前
「Flutter三方库sqflite的鸿蒙化适配与实战指南:从入门到踩坑的本地数据库开发全记录」
数据库·flutter·华为·信息可视化·数据库开发·harmonyos
前端技术6 小时前
HarmonyOS开发:鸿蒙应用开发发展史
华为·harmonyos
忡黑梨6 小时前
eNSP_路由策略
运维·服务器·网络·华为·智能路由器·负载均衡
Hello__77777 小时前
开源鸿蒙 Flutter 实战|自定义头像组件全流程实现
flutter·华为·harmonyos
模拟IC攻城狮7 小时前
华为2026 年校园招聘——硬件技术工程师-电源方向-机试题(12套)(每套四十题)
嵌入式硬件·华为·硬件架构·芯片
花先锋队长7 小时前
从“耐刮”到“通透”:华为抗反光耐刮昆仑玻璃,如何重新定义屏幕体验?
华为
IntMainJhy8 小时前
【flutter for open harmony】第三方库Flutter成就解锁彩纸动画的鸿蒙化适配与实战指南
harmonyos
sdszoe49228 小时前
华为设备安全管理之路由器+ACL
网络·安全·华为·路由器+acl
Lanren的编程日记8 小时前
任务77:Flutter 鸿蒙应用视频录制功能实战:视频录制+录制控制+视频编辑,打造完整视频处理能力
flutter·音视频·harmonyos
Hello__77778 小时前
开源鸿蒙 Flutter 实战|进度条组件全流程实现
flutter·开源·harmonyos