Blame view

src/components/page/options.vue 2.55 KB
7fa943eb   梁灏   init
1
2
3
  <template>
      <div v-if="showSizer || showElevator" :class="optsClasses">
          <div v-if="showSizer" :class="sizerClasses">
6932b4d7   梁灏   update Page compo...
4
              <i-select :model.sync="pageSize" :size="size" @on-change="changeSize">
e355dd49   梁灏   add Select Component
5
6
                  <i-option v-for="item in pageSizeOpts" :value="item" style="text-align:center;">{{ item }} 条/页</i-option>
              </i-select>
7fa943eb   梁灏   init
7
8
9
10
11
12
13
14
15
          </div>
          <div v-if="showElevator" :class="ElevatorClasses">
              跳至
              <input type="text" :value="_current" @keyup.enter="changePage">
  
          </div>
      </div>
  </template>
  <script>
e355dd49   梁灏   add Select Component
16
17
18
      import iSelect from '../../components/select/select.vue';
      import iOption from '../../components/select/option.vue';
  
7fa943eb   梁灏   init
19
20
21
22
23
24
25
      const prefixCls = 'ivu-page';
  
      function isValueNumber (value) {
          return (/^[1-9][0-9]*$/).test(value + '');
      }
  
      export default {
e355dd49   梁灏   add Select Component
26
          components: { iSelect, iOption },
7fa943eb   梁灏   init
27
28
29
30
31
32
33
          props: {
              pageSizeOpts: Array,
              showSizer: Boolean,
              showElevator: Boolean,
              current: Number,
              _current: Number,
              pageSize: Number,
6932b4d7   梁灏   update Page compo...
34
35
              allPages: Number,
              isSmall: Boolean
7fa943eb   梁灏   init
36
37
          },
          computed: {
6932b4d7   梁灏   update Page compo...
38
39
40
              size () {
                  return this.isSmall ? 'small' : 'default';
              },
7fa943eb   梁灏   init
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
              optsClasses () {
                  return [
                      `${prefixCls}-options`
                  ]
              },
              sizerClasses () {
                  return [
                      `${prefixCls}-options-sizer`
                  ]
              },
              ElevatorClasses () {
                  return [
                      `${prefixCls}-options-elevator`
                  ]
              }
          },
          methods: {
              changeSize () {
                  this.$emit('on-size', this.pageSize);
              },
              changePage (event) {
                  let val = event.target.value.trim();
                  let page = 0;
  
                  if (isValueNumber(val)) {
                      val = Number(val);
                      if (val != this.current) {
                          const allPages = this.allPages;
  
                          if (val > allPages) {
                              page = allPages;
                          } else {
                              page = val;
                          }
                      }
                  } else {
                      page = 1;
                  }
  
                  if (page) {
                      this.$emit('on-page', page);
                      event.target.value = page;
                  }
              }
          }
      }
  </script>