ホームページ >ウェブフロントエンド >jsチュートリアル >Bootstrap4 + Vue2 でページング クエリを実装する方法

Bootstrap4 + Vue2 でページング クエリを実装する方法

亚连
亚连オリジナル
2018-06-19 14:55:402663ブラウズ

この記事では、Bootstrap4 + Vue2 を使用してページング クエリを実装するサンプル コードを主に紹介します。

前に書きます

このプロジェクトは、フロントエンドとバックエンドを分離するように設計されており、フロントエンド リソース サーバーとして Nginx を使用し、バックエンド サービスにリバース プロキシを実装します。バックグラウンドは、Tomcat を使用してサービスをデプロイする Java Web プロジェクトです。

  1. フロントエンドフレームワーク: Bootstrap4、Vue.js2

  2. バックエンドフレームワーク: Spring Boot、Spring Data JPA

  3. 開発ツール: IntelliJ IDEA、Maven

成果効果:

メンバー情報

Bootstrap + Vueを使って動的テーブルを実装したり、データの追加や削除などを行う方法については、Bootstrap + Vue.jsを使って動的テーブルの表示や追加、削除を実装するをご覧ください。説明が終わったら、この記事の本題に入ります。

1. Bootstrapを使用してテーブルを構築

テーブル領域

<p class="row">
   <table class="table table-hover table-striped table-bordered table-sm">
    <thead class="">
    <tr>
     <th><input type="checkbox"></th>
     <th>序号</th>
     <th>会员号</th>
     <th>姓名</th>
     <th>手机号</th>
     <th>办公电话</th>
     <th>邮箱地址</th>
     <th>状态</th>
    </tr>
    </thead>
    <tbody>
    <tr v-for="(user,index) in userList">
     <td><input type="checkbox" :value="index" v-model="checkedRows"></td>
     <td>{{pageNow*10 + index+1}}</td>
     <td>{{user.id}}</td>
     <td>{{user.username}}</td>
     <td>{{user.mobile}}</td>
     <td>{{user.officetel}}</td>
     <td>{{user.email}}</td>
     <td v-if="user.disenable == 0">正常</td>
     <td v-else>注销</td>
    </tr>
    </tbody>
   </table>
  </p>

ページング領域

Vueオブジェクトを作成する

<p class="row mx-auto">
   <ul class="nav justify-content-center pagination-sm">
    <li class="page-item">
     <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link"><i class="fa fa-fast-backward" @click="switchToPage(0)"> </i></a>
    </li>
    <li class="page-item">
     <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link"><i class="fa fa-backward" @click="switchToPage(pageNow-1)"></i></a>
    </li>
    <li class="page-item" v-for="n in totalPages" :class="{active:n==pageNow+1}">
     <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" @click="switchToPage(n-1)" class="page-link">{{n}}</a>
    </li>
    <li class="page-item">
     <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link"><i class="fa fa-forward" @click="switchToPage(pageNow+1)"></i></a>
    </li>
    <li class="page-item">
     <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link"><i class="fa fa-fast-forward" @click="switchToPage(totalPages-1)"></i></a>
    </li>
   </ul>
  </p>
データを初期化する
var vueApp = new Vue({
  el:"#vueApp",
  data:{
   userList:[],
   perPage:10,
   pageNow:0,
   totalPages:0,
   checkedRows:[]
  },
  methods:{
   switchToPage:function (pageNo) {
    if (pageNo < 0 || pageNo >= this.totalPages){
     return false;
    }
    getUserByPage(pageNo);
   }
  }
 });

コード:

function getUserByPage(pageNow) {
 $.ajax({
  url:"/user/"+pageNow,
  success:function (datas) {
  vueApp.userList = datas.content;
  vueApp.totalPages = datas.totalPages;
  vueApp.pageNow = pageNow;
  },
  error:function (res) {
  console.log(res);
  }
 });
 }

3. JPA を使用してページング クエリを実装します

コントローラーはリクエストを受け取ります

<script>
 var vueApp = new Vue({
 el:"#vueApp",
 data:{
  userList:[],
  perPage:10,
  pageNow:0,
  totalPages:0,
  checkedRows:[]
 },
 methods:{
  switchToPage:function (pageNo) {
  if (pageNo < 0 || pageNo >= this.totalPages){
   return false;
  }
  getUserByPage(pageNo);
  }
 }
 });
 getUserByPage(0);
 function getUserByPage(pageNow) {
 $.ajax({
  url:&quot;/user/&quot;+pageNow,
  success:function (datas) {
  vueApp.userList = datas.content;
  vueApp.totalPages = datas.totalPages;
  vueApp.pageNow = pageNow;
  },
  error:function (res) {
  console.log(res);
  }
 });
 }
</script>
JPA ページング クエリ
/**
 * 用户相关请求控制器
 * @author louie
 * @date 2017-12-19
 */
@RestController
@RequestMapping("/user")
public class UserController {

 @Autowired
 private UserService userService;

 /**
 * 分页获取用户
 * @param pageNow 当前页码
 * @return 分页用户数据
 */
 @RequestMapping("/{pageNow}")
 public Page<User> findByPage(@PathVariable Integer pageNow){
 return userService.findUserPaging(pageNow);
 }
}

これで関数は完了しました。プロジェクト コードは GitHub で共有されています。クリックして表示できます。または、ダウンロードしてオープンソースを採用し、世界をより良い場所にしようと共有します。

上記は私があなたのためにまとめたものです。

関連記事:

jQuery+CSS を使用してテーブルを実装する方法

http モジュールを使用して、nodejs 経由でリクエストを送信する (詳細なチュートリアル)

Angular を使用して国際化を実装する方法 (詳細なチュートリアル)

JQuery はフォーム検証をどのように実装するのでしょうか?具体的には何を行う必要がありますか?

Vueを使用して複数のクラスを設定する方法

以上がBootstrap4 + Vue2 でページング クエリを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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