HarmonyOS refresh组件web组件时下拉事件不生效

refresh组件web组件时下拉事件不生效demo代码如下:

import web_webview from '@ohos.web.webview'; 
 
@Entry 
@Component 
struct Index { 
  @State isRefreshing: boolean = false 
  @State url: string = 'https://www.huawei.com' 
  @State controller: web_webview.WebviewController = new web_webview.WebviewController() 
 
  build() { 
    Column() { 
      Refresh({ refreshing: $$this.isRefreshing}) { 
        Web({ src: this.url, controller: this.controller }) 
          .align(Alignment.Center) 
          .width('100%') 
          .height('100%') 
          .backgroundColor(Color.Red) 
          .domStorageAccess(true) 
      } 
      .onStateChange((refreshStatus: RefreshStatus) => { 
        console.info('Refresh onStatueChange state is ' + refreshStatus) 
      }) 
      .onRefreshing(() => { 
        setTimeout(() => { 
          this.isRefreshing = false 
        }, 2000) 
        console.log('onRefreshing test') 
      }) 
      .backgroundColor(0x89CFF0) 
    } 
  } 
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
HarmonyOS
2024-11-07 11:43:16
3111浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
Heiang

​当前不支持Refresh组件+Web组件实现webview内下拉刷新,但可通过三方开源库@ohos/pulltorefresh实现该效果,三方库地址:https://ohpm.openharmony.cn/#/cn/detail/@ohos%2Fpulltorefresh

安装:ohpm install @ohos/pulltorefresh

示例代码:​

import web_webview from '@ohos.web.webview'; 
import { PullToRefresh } from '@ohos/pulltorefresh' 
 
@Entry 
@Component 
struct Index { 
  controller: web_webview.WebviewController = new web_webview.WebviewController(); 
  @State dataArray: Array<string> = [] 
  private scroller: Scroller = new Scroller(); 
 
 
  @Builder 
  getContentView() { 
    Column() { 
      Web({ src: 'http://www.huawei.com', controller: this.controller }) 
    }.width('100%').height('100%') 
  } 
 
 
  build() { 
    Scroll(this.scroller) { 
      PullToRefresh({ 
        data: $dataArray, 
        scroller: this.scroller, 
        customList: () => { 
          this.getContentView(); 
        }, 
        onRefresh: () => { 
          return new Promise<string>((resolve, reject) => { 
            setTimeout(() => { 
              resolve('') 
              this.controller.loadUrl('https://www.huawei.com') 
            }, 1000); 
          }); 
        }, 
      }).width('100%').height('100%') 
    }.width('100%').height('100%') 
  } 
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
分享
微博
QQ
微信
回复
2024-11-07 14:53:30
相关问题
Web组件的onKeyEvent键盘事件生效
2575浏览 • 1回复 待解决
HarmonyOS Web组件borderRadius生效
1062浏览 • 1回复 待解决
容器组件onVisibleAreaChange生效
2767浏览 • 1回复 待解决
HarmonyOS Refresh禁用下拉
701浏览 • 1回复 待解决
HarmonyOS 组件切换深色模式生效
1258浏览 • 1回复 待解决
HarmonyOS ArkWeb组件加载url生效
1031浏览 • 1回复 待解决
在嵌套组件中Scroll生效
2806浏览 • 1回复 待解决
HarmonyOS Web组件怎么添加下拉刷新
696浏览 • 1回复 待解决
List组件的initialIndex属性设置生效
2954浏览 • 1回复 待解决
HarmonyOS Refresh + Web?
531浏览 • 0回复 待解决