ElementUIページングコンポーネントPagination in Vueの使用は参考になります。具体的な内容は次のとおりです。 1. 概要ElementUI はel-paginationコンポーネントを提供します。対応するパラメータとイベントを構成することでページネーションを実現できます。 2. 実装1. 基本的な使い方 <div class="ページネーション"> <el-ページネーション 背景 layout="total, sizes, prev, pager, next, jumper" :current-page="テーブルページ.ページ番号" :page-size="テーブルページ.ページサイズ" :page-sizes="ページサイズ" :total="テーブルページの合計" @size-change="ハンドルサイズ変更" @current-change="ページ変更処理" /> </div> データ() { 戻る { テーブルページ: { pageNum: 1, // ページ番号 pageSize: 10, // ページあたりのレコード数 total: 0 // レコードの総数 }, ページサイズ: [10, 20, 30] } }, メソッド: { ページ変更処理(現在のページ) { this.tablePage.pageNum = 現在のページ // ここでデータを更新}, ページサイズの変更処理 this.tablePage.pageSize = ページサイズ // ここでデータを更新} } 2. バックエンドページングの実装 実装のアイデア: バックエンドにリクエストを送信し、pageNum と pageSize の 2 つのパラメータを渡し、対応するページング データを直接取得します。 // データを取得する getData() { パラメータ = { ページ番号: this.tablePage.pageNum、 ページサイズ: this.tablePage.pageSize } // バックエンドインターフェースをリクエストする function getDataApi(param, { loading: true }).then(res => { //バックグラウンドでデータを返す this.list = res.data.list this.tablePage.total = res.data.total }) }, 3. フロントエンドページングの実装 実装のアイデア:すべてのデータを取得するためにバックグラウンドにリクエストを送信します。フロントエンドは pageNum と pageSize を通じてデータを処理し、最終的に対応するページング データを取得します。データを処理するには 2 つの方法があります。 1. Array.slice を使用して、必要な配列フラグメントを抽出します (この方法では、ページの合計数「1」と最後のページが考慮されます) /** * ページングデータ処理 * @param data [配列] ページ分割するデータ * @param num [数値] 現在のページ * @param size [数値] 1ページあたりに表示する項目数 */ getList(データ、数値、サイズ) { リスト、合計、開始、終了、isFirst、isLast を取得します。 合計 = データの長さ isFirst = 合計 < サイズ isLast = Math.ceil(合計 / サイズ) === num 開始 = (数値 - 1) * サイズ end = isFirst || isLast ? start + (合計 % サイズ) : start + サイズ リスト = data.slice(開始、終了) list.forEach((項目, インデックス) => { item.seq = インデックス + 開始 }) 返品リスト } /** * ページングデータ処理 * @param data [配列] ページ分割するデータ * @param num [数値] 現在のページ * @param size [数値] 1ページあたりに表示する項目数 */ getList(データ、数値、サイズ) { let リスト、開始、終了 開始 = (数値 - 1) * サイズ 終了 = 開始 + サイズ リスト = data.filter((item, index) => { インデックス >= 開始 && インデックス < 終了を返します }) list.forEach((項目, インデックス) => { item.seq = インデックス + 開始 }) 返品リスト } 概要:フロントエンド ページングでもバックエンド ページングでも、最終的には pageNum (現在のページ) と pageSize (ページあたりのエントリ数) の 2 つのパラメーターが必要になります。 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: ページングのどのページでMySQLのレコードをクエリするか
>>: VMware 仮想マシンのインストール CentOS 8 (1905) システム チュートリアル ダイアグラム
目次1. 需要1. 需要2. SDKパラメータ設定1. ディレクトリ構造3. コードの実装1. バッ...
以下の目標を達成するため: Mysql データベースは、一定の間隔 (2 時間または 1 日、カスタ...
Gitlab と Github の違いについては、あまり説明する必要はありません。一言でまとめると、...
1.docker search mysql查看mysql版本 2. docker pull mysq...
この記事の例では、WeChatアプレットで画像コントロールを選択するための具体的なコードを参考までに...
序文私が使用しているパソコンはMacで、OSはmacOS Mojaveです。コンピュータに仮想マシン...
1. HTMLの概要htyper テキスト マークアップ言語 ハイパーテキスト マークアップ言語ハ...
背景<br />フロントエンドを担当する学生は、ページが多すぎると煩雑になるため、開発プ...
MySQL のインストールは比較的簡単なので、通常は次のステップに直接進み、注意が必要な点に集中する...
これは非常にシンプルな純粋な CSS3 の白い雲の浮遊する背景効果です。浮かぶ白い雲の特殊効果は、C...
ステップ1: Djangoプロジェクトを作成するターミナルを開き、書き込みたいプロジェクトのアドレス...
オフィスでは、Linux 開発環境として Ubuntu システムが必要です。現在、Ubuntu 16...
mysql 1 つのテーブル列を別のテーブルにコピーする場合によっては、フィールドから別の新しいフィ...
VMware Workstationsが仮想マシンエラーを起動する エラー レポートのリンク htt...
序文データベース トランザクションに関して言えば、トランザクションの ACID 特性、分離レベル、解...