HarmonyOS 监听List组件滑动
想要实现滚动List列表,顶部导航背景色透明度渐变效果,通过onDidScroll()实现,代码如下:
List({ space: 10, scroller: this.listScroller }) {
  ListItemGroup() {
    ListItem() {
    }
    .width('100%')
    .height(100)
  }
  ListItemGroup({ header: this.itemHead('A') }) {
    ListItem() {
      Text('北京').fontSize(24)
    }
    ListItem() {
      Text('杭州').fontSize(24)
    }
    ListItem() {
      Text('上海').fontSize(24)
    }
  }
  .borderRadius(6)
  // .width(px2vp(display.getDefaultDisplaySync().width)-28)
  ListItemGroup({ header: this.itemHead('B') }) {
    // 循环渲染分组B的ListItem
    ListItem() {
      Text('北京').fontSize(24)
    }
    ListItem() {
      Text('杭州').fontSize(24)
    }
    ListItem() {
      Text('上海').fontSize(24)
    }
  }
  .backgroundColor(Color.White)
  .borderRadius(6)
  .width(px2vp(display.getDefaultDisplaySync().width)-28)
  .margin({ left: 14, right: 14 })
  ListItemGroup({ header: this.itemHead('B') }) {
    // 循环渲染分组B的ListItem
    ListItem() {
      Text('北京').fontSize(24)
    }
    ListItem() {
      Text('杭州').fontSize(24)
    }
    ListItem() {
      Text('上海').fontSize(24)
    }
  }
  .backgroundColor(Color.White)
  .borderRadius(6)
  .width(px2vp(display.getDefaultDisplaySync().width)-28)
  .margin({ left: 14, right: 14 })
}
.width(LUCCUIConstants.LUCCUI_FULL_SIZE)
.height(LUCCUIConstants.LUCCUI_FULL_SIZE)
.backgroundColor(Color.Transparent)
.scrollBar(BarState.Off)
.alignListItem(ListItemAlign.Start)
.onDidScroll((scrollOffset: number, scrollState: ScrollState) => {
  this.imageOffsetY = scrollOffset
  if (scrollOffset > 0 && scrollOffset < 50) {
    this.naviModel.bgOpacity = scrollOffset/50.0
  } else {
    this.naviModel.bgOpacity = scrollOffset<=0 ? 0 : 1
  }
})
发现效果不对
        HarmonyOS
      
        赞
        
 收藏 0
 回答 1
 
        待解决
        
相关问题
 如何监听List组件的总滑动距离 
4251浏览  • 1回复 待解决
HarmonyOS List组件如何监听滑动到底部? 
2214浏览  • 1回复 待解决
HarmonyOS  组件List如何禁止滑动 
2384浏览  • 1回复 待解决
HarmonyOS 可滑动组件嵌套后内部的可滑动组件无法监听滑动 
1082浏览  • 1回复 待解决
HarmonyOS List组件的滚动监听 
1216浏览  • 1回复 待解决
HarmonyOS  list组件如何设置匀速滑动 
796浏览  • 1回复 待解决
HarmonyOS如何去掉List组件的滑动线 
2167浏览  • 1回复 待解决
HarmonyOS的List组件滑动卡顿怎么优化? 
725浏览  • 0回复 待解决
HarmonyOS list无法滑动 
763浏览  • 1回复 待解决
HarmonyOS List联动滑动 
888浏览  • 1回复 待解决
web组件和list嵌套滚动,在出现list后向下滑动,出现web滑动list不动的情况 
3018浏览  • 1回复 待解决
HarmonyOS Refresh跟list组件惯性滑动问题 
1142浏览  • 1回复 待解决
HarmonyOS  如何获取List组件当前已经滑动的距离 
1498浏览  • 1回复 待解决
HarmonyOS List组件滑动限制为1页的问题 
698浏览  • 1回复 待解决
HarmonyOS 如何实现滑动监听? 
1642浏览  • 1回复 待解决
scroll包裹list,scroll可以响应滑动,list不能响应滑动 
2595浏览  • 1回复 待解决
HarmonyOS 如何实现list组件item滑动到中间高亮显示 
1258浏览  • 1回复 待解决
HarmonyOS list滑动问题 
1854浏览  • 1回复 待解决
List 组件使用 scroller 的 scrollTo 控制滑动时,能否取消滑动动画? 
2803浏览  • 1回复 待解决
HarmonyOS Swiper组件支持滑动监听以及设置具体滚动位置 
1589浏览  • 1回复 待解决
HarmonyOS list组件包含tab组件上下滑动冲突解决方案 
1208浏览  • 1回复 待解决
弹窗里面写了List组件,ListItem是否还支持滑动 
2954浏览  • 1回复 待解决
如何设置List组件滑动到边缘无回弹效果 
4110浏览  • 1回复 待解决
HarmonyOS list嵌套MapComponent滑动冲突 
909浏览  • 1回复 待解决
HarmonyOS Web组件在List中使用时的滑动问题 
896浏览  • 1回复 待解决





















onDidScroll中的scrollOffset换成listScroller.currentOffset 试下
scrollOffset返回当前帧滚动的偏移量,currentOffset能够获取到当前准确的滑动位置