Commit 61a93779 authored by Decade's avatar Decade Committed by 杨奕

Pagination: reset invalid jumper value (#8408)

* fix pagination jumper value

* fix lint
parent 744478b8
......@@ -203,6 +203,17 @@ export default {
handleChange({ target }) {
this.$parent.internalCurrentPage = this.$parent.getValidCurrentPage(target.value);
this.oldValue = null;
this.resetValueIfNeed(target);
},
resetValueIfNeed(target) {
const num = parseInt(target.value, 10);
if (!isNaN(num)) {
if (num < 1) {
target.value = 1;
} else {
this.reassignMaxValue(target);
}
}
},
reassignMaxValue(target) {
if (+target.value > this.$parent.internalPageCount) {
......
......@@ -214,6 +214,7 @@ describe('Pagination', () => {
triggerEvent(input, 'change');
setTimeout(() => {
expect(vm.page).to.equal(1);
expect(input.value).to.equal('1');
input.value = 10000;
triggerEvent(input, 'change');
......@@ -225,7 +226,38 @@ describe('Pagination', () => {
triggerEvent(input, 'change');
setTimeout(() => {
expect(vm.page).to.equal(1);
done();
expect(input.value).to.equal('1');
// 多次输入不在min-max区间内的数字
input.value = 0;
triggerEvent(input, 'change');
setTimeout(()=>{
expect(vm.page).to.equal(1);
expect(input.value).to.equal('1');
input.value = 0;
triggerEvent(input, 'change');
setTimeout(()=>{
expect(vm.page).to.equal(1);
expect(input.value).to.equal('1');
input.value = 1000;
triggerEvent(input, 'change');
setTimeout(()=>{
expect(vm.page).to.equal(10);
expect(input.value).to.equal('10');
input.value = 1000;
triggerEvent(input, 'change');
setTimeout(()=>{
expect(vm.page).to.equal(10);
expect(input.value).to.equal('10');
done();
}, 50);
}, 50);
}, 50);
}, 50);
}, 50);
}, 50);
}, 50);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment