ホームページ ウェブフロントエンド uni-app uniappがプルアップイベントを監視できない問題の解決方法

uniappがプルアップイベントを監視できない問題の解決方法

Apr 20, 2023 am 09:11 AM

uniapp では、ページ スクロール イベントをリッスンすることで、より多くのプルアップ読み込み関数を実装できます。しかし、ページが一番下にスライドしてもプルアップ イベントを監視できない場合があります。

最初に明確にしておきたいのは、uniapp は Vue フレームワークに基づいて開発されているため、この問題を解決するために Vue のアイデアから学ぶことができるということです。 Vue には v-infinite-scroll という命令が用意されており、これは一番下までスクロールするときにメソッドをトリガーすることができ、非常に便利です。ただし、uniapp はこの命令をサポートしていないため、手動で実装する必要があります。

実装の考え方は、ページをスクロールしたときに一番下にスライドしたかどうかを判定することです。一番下にスライドすると、プルアップ メソッドをトリガーしてさらに読み込みます。具体的な実装コードは次のとおりです。

<template>
  <view>
    <!-- 此处放置列表数据 -->

  </view>
</template>

<script>
export default {
  data() {
    return {
      // 列表数据
      listData: [],
      // 是否加载中
      isLoading: false,
      // 页面滚动距离
      scrollTop: 0,
      // 页面可见高度
      windowHeight: uni.getSystemInfoSync().windowHeight,
      // 页面总高度
      scrollHeight: 0,
      // 每页数据条数
      pageSize: 10,
      // 当前页数
      pageNum: 1,
      // 总页数
      totalPage: 0
    }
  },
  onLoad() {
    // 初始化数据
    this.getData()
  },
  methods: {
    // 获取数据
    getData() {
      // 加载中不允许重复请求
      if (this.isLoading) {
        return
      }

      // 加载中状态
      this.isLoading = true

      // 请求数据
      api.getData({
        pageNum: this.pageNum,
        pageSize: this.pageSize
      }).then(res => {
        // 数据加载完成后,将isLoading改为false,更新数据
        this.isLoading = false
        this.listData = this.listData.concat(res.list)
        this.totalPage = res.totalPage

        // 更新页面总高度,以便后面判断
        uni.createSelectorQuery().in(this).select('.list-container').boundingClientRect(data => {
          if (data) {
            this.scrollHeight = data.height
          }
        }).exec()
      })
    },
    // 上拉加载更多
    onScrollToLower() {
      // 判断当前页数是否小于总页数,否则禁止继续加载
      if (this.pageNum >= this.totalPage) {
        return
      }

      // 判断是否满足上拉加载更多的条件
      if (this.scrollTop + this.windowHeight >= this.scrollHeight) {
        // 加载下一页数据
        this.pageNum++
        this.getData()
      }
    },
    // 监听页面滚动事件,更新页面滚动距离
    onPageScroll(obj) {
      this.scrollTop = obj.scrollTop
    }
  }
}
</script>
ログイン後にコピー

このコードでは、最初にリスト データ listData と、ページごとのデータ項目数 pageSize や現在のページ番号 pageNum などのいくつかのページング関連変数を定義します。ページの読み込み時にデータを初期化し、最初のページのデータを取得します。

ページの一番下までスクロールすると、onScrollToLower メソッドがトリガーされます。このメソッドでは、まず現在のページ番号が合計ページ番号より小さいかどうかを判断します。それより大きいか等しい場合は、総ページ数の場合は、これ以上データが無いことを意味しますが、ロードできるのでそのままリターンしてください。それ以外の場合は、現在位置がページの下部に移動したかどうかを確認し、移動している場合は、プルアップ メソッドをトリガーしてさらに読み込むようにします。

主にページのスクロール距離scrollTopを更新するために、ページスクロールイベントをリッスンします。データを初期化した後、uni.createSelectorQuery().in(this).select('.list-container').boundingClientRect(data => {}) を使用してページの合計高さscrollHeightを取得し、ページまでスクロールします。下部で、scrollTop windowHeight がscrollHeight と等しいかどうかを確認して、ページの下部にスライドしたかどうかを判断します。

なお、この実装方法はリストのデータ量が多くない場合にのみ適用できるため、データ量が多すぎるとページがフリーズしたり、スライドが滑らかでなくなる可能性があります。この時点で、ページにデータをロードするか、サードパーティのコンポーネントを使用して、Mescroll などのプルアップ ロード機能を実装することを検討できます。

つまり、プルアップを実装してより多くの機能を搭載することは難しいことではなく、Vueの考え方を柔軟に活用し、uniappが提供するAPIを利用して実現することが鍵となります。

以上がuniappがプルアップイベントを監視できない問題の解決方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Uni-Appのソーシャル共有APIを使用するにはどうすればよいですか? Uni-Appのソーシャル共有APIを使用するにはどうすればよいですか? Mar 13, 2025 pm 06:30 PM

この記事では、ソーシャル共有をUni.share APIを使用してUni-Appプロジェクトに統合し、WeChatやWeiboなどのプラットフォーム全体でセットアップ、構成、テストをカバーする方法を詳しく説明しています。

Uni-APPでプレ前セッサー(SASS、LESS)を使用するにはどうすればよいですか? Uni-APPでプレ前セッサー(SASS、LESS)を使用するにはどうすればよいですか? Mar 18, 2025 pm 12:20 PM

記事では、UNI-APPでSASSおよびPREPROCESSORSを使用して、セットアップ、利点、および二重使用法を詳細に使用することについて説明します。主な焦点は構成と利点にあります。[159文字]

Uni-AppのアニメーションAPIを使用するにはどうすればよいですか? Uni-AppのアニメーションAPIを使用するにはどうすればよいですか? Mar 18, 2025 pm 12:21 PM

この記事では、Uni-AppのアニメーションAPIの使用方法、アニメーション、キー関数、およびアニメーションのタイミングを結合および制御する方法を作成および適用する手順を詳細に説明します。

UNIAPPアプリケーションで実行できるさまざまなタイプのテストは何ですか? UNIAPPアプリケーションで実行できるさまざまなタイプのテストは何ですか? Mar 27, 2025 pm 04:59 PM

この記事では、ユニット、統合、機能、UI/UX、パフォーマンス、クロスプラットフォーム、セキュリティテストなど、UNIAPPアプリケーションのさまざまなテストタイプについて説明します。また、クロスプラットフォームの互換性を確保し、JESのようなツールを推奨しています

Uniappアプリケーションパッケージのサイズをどのように削減できますか? Uniappアプリケーションパッケージのサイズをどのように削減できますか? Mar 27, 2025 pm 04:45 PM

この記事では、コードの最適化、リソース管理、コード分割や怠zyなロードなどの手法に焦点を当てたUniappパッケージサイズを削減する戦略について説明します。

uni-appのストレージAPI(uni.setstorage、uni.getStorage)を使用するにはどうすればよいですか? uni-appのストレージAPI(uni.setstorage、uni.getStorage)を使用するにはどうすればよいですか? Mar 18, 2025 pm 12:22 PM

この記事では、ローカルデータ管理のためにUni-AppのストレージAPI(uni.setstorage、uni.getStorage)を使用する方法について説明し、ベストプラクティス、トラブルシューティング、および効果的な使用のための制限と考慮事項について説明します。

UNI-APPプロジェクトのファイル構造は何ですか? UNI-APPプロジェクトのファイル構造は何ですか? Mar 14, 2025 pm 06:55 PM

この記事は、Uni-APPプロジェクトのファイル構造を詳しく説明し、一般的な、コンポーネント、ページ、静的、ユニクロードなどの主要なディレクトリ、およびapp.vue、main.js、manifest.json、pages.json、uni.scssなどの重要なファイルを説明します。これがどのようにoです

UniappのWebパフォーマンスのために画像を最適化するにはどうすればよいですか? UniappのWebパフォーマンスのために画像を最適化するにはどうすればよいですか? Mar 27, 2025 pm 04:50 PM

この記事では、圧縮、レスポンシブデザイン、怠zyなロード、キャッシング、およびWebP形式の使用を通じて、Webパフォーマンスを向上させるために、Uniappの画像の最適化について説明します。

See all articles