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>
|