28
23

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Vue.jsでpagerを実装

Last updated at Posted at 2018-11-10

Vue.jsで「vuejs-paginate」を使ってpagerを実装したので、その手順を書きたいと思います。
下記の手順で実装しました。

  1. 「vuejs-paginate」をinstall
  2. paginate componentに設定
  3. Listの番号をstoreで管理して、Listに表示するデータを設定

「vuejs-paginate」をinstall

$ yarn add vuejs-paginate

paginate componentに設定

「vuejs-paginate」をinstallしたので、公式サイトを元に「Pagination.vue」に設定していきます。

Pagination.vue

<template>
  <paginate
    v-model="page"
    :page-count="20"
    :page-range="3"
    :margin-pages="2"
    :click-handler="clickCallback"
    :prev-text="'Prev'"
    :next-text="'Next'"
    :container-class="'pagination'"
    :page-class="'page-item'">
  </paginate>
</template>

<script>
import Vue from 'vue';
import Paginate from 'vuejs-paginate';
Vue.component('paginate', Paginate);
</script>

Listの番号をstoreで管理して、Listに表示するデータを設定

考えたこと

ここまではpackageの公式サイトを見ればそのまんまなので苦労しないですが、ここから実際にpagerの番号とListに表示するデータを連動させないといけないので改修が必要になります。

で、僕がこの「pagerの番号」をstoreで管理しました。
なぜならその番号がListに表示するデータに関係していて、且つそれらはcomponentで分かれていたのでそれをstoreで横断したいなと思ったので。

コード

まずはVuexでstoreを読み込んでインスタンスしたものを#appで読み込ませます。

main.js
import Vue from 'vue';
import Vuex from 'vuex';
import _store from './store';

Vue.use(Vuex);

const store = new Vuex.Store(_store);

new Vue({
  el: '#app',
  components: { App },
  template: '<App/>',
  store,
});
store.js
const state = {
  paginationNUmber: 1, // pagerの番号です。デフォルトを設定
};

次に先ほど設定した Pagination.vueを改修します

Pagination.vue
<template>
  <paginate
    v-model="page"
    :page-count="paginationNumber" // pagerの数
    :page-range="20" // 1ページに表示するListの数
    :margin-pages="0"
    :prev-text=null
    :next-text=null
    :click-handler="clickCallback"
    :container-class="'pagination'"
    :page-class="'page-item'">
  </paginate>
</template>

<script>
import Vue from 'vue';
import Paginate from 'vuejs-paginate';

Vue.component('paginate', Paginate);

export default {
  data() {
    return {
      length: 20, // 1ページに表示するListの数
      page: this.$store.state.paginationNUmber, // storeからpage番号を取得
    };
  },
  methods: {
    clickCallback(pageNum) {
      this.page = pageNum; // pageNumはpagerの何番目をclickしたかを取得
      this.$store.state.paginationNUmber = pageNum; // 何番目をclickしたかをstoreの値にset
    },
  },
  computed: {
    paginationNumber() {
      return this.$store.state.hoge.length / 20; // pagerの数を設定するために全データの数を20で割っている
    },
  },
};
</script>

次にListを実装するため$store.state.paginationNUmberを取得してデータを表示する。

hoge.vue
<template>
  <div>
    <list
      :hoge="sharedState.hoge" // listの全データ
      :start="listStart"
      :count="length"
    >
    </work-list>
    <pagination></pagination>
  </div>
</template>

<script>
import List from '../components/List';
import Pagination from '../components/Pagination';

export default {
  data() {
    return {
      length: 20,
    };
  },
  computed: {
    sharedState() {
      return this.$store.state;
    },
    listStart() {
      return 20 * (this.$store.state.paginationNUmber - 1); // 表示したいデータの最初の値。0、20、40...
    },
  },
  components: {
    List,
    Pagination,
  },
};
</script>
List.vie
<template>
  <div>
    <ul>
      <item
        v-for="(item, index) in filtered" :key="index"
        :hoge="hoge"
      >
    </ul>
  </div>
</template>

<script>
import Item from './Item';

export default {
  props: {
    hoge: Array, // listの全データ
    start: Number,
    count: Number,
  },
  computed: {
    filtered() {
      let list = this.hoge.concat();
      if (this.count) {
        list = list.splice(this.start, this.count); // 表示したデータを取得。1〜20、21〜40、41〜60...の20ごとのデータを取得
      }
      return list;
    },
  },
  components: {
    Item,
  },
};
</script>

実際のコードから割愛していますがこのようなコードで実装してみました。
合っていますでしょうか?

実装後のview

01.jpg

参考サイト

28
23
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
28
23

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?