mirror of https://github.com/ElemeFE/element
input number fix change event & improve
parent
882a9d796e
commit
190211d4a9
|
@ -6,31 +6,11 @@
|
||||||
{ 'is-without-controls': !controls}
|
{ 'is-without-controls': !controls}
|
||||||
]"
|
]"
|
||||||
>
|
>
|
||||||
<el-input
|
|
||||||
:value="currentValue"
|
|
||||||
@keydown.up.native="increase"
|
|
||||||
@keydown.down.native="decrease"
|
|
||||||
@blur="handleBlur"
|
|
||||||
@input="handleInput"
|
|
||||||
:disabled="disabled"
|
|
||||||
:size="size"
|
|
||||||
:class="{
|
|
||||||
'is-active': inputActive
|
|
||||||
}">
|
|
||||||
<template slot="prepend" v-if="$slots.prepend">
|
|
||||||
<slot name="prepend"></slot>
|
|
||||||
</template>
|
|
||||||
<template slot="append" v-if="$slots.append">
|
|
||||||
<slot name="append"></slot>
|
|
||||||
</template>
|
|
||||||
</el-input>
|
|
||||||
<span
|
<span
|
||||||
v-if="controls"
|
v-if="controls"
|
||||||
class="el-input-number__decrease el-icon-minus"
|
class="el-input-number__decrease el-icon-minus"
|
||||||
:class="{'is-disabled': minDisabled}"
|
:class="{'is-disabled': minDisabled}"
|
||||||
v-repeat-click="decrease"
|
v-repeat-click="decrease"
|
||||||
@mouseenter="activeInput(minDisabled)"
|
|
||||||
@mouseleave="inactiveInput(minDisabled)"
|
|
||||||
>
|
>
|
||||||
</span>
|
</span>
|
||||||
<span
|
<span
|
||||||
|
@ -38,10 +18,23 @@
|
||||||
class="el-input-number__increase el-icon-plus"
|
class="el-input-number__increase el-icon-plus"
|
||||||
:class="{'is-disabled': maxDisabled}"
|
:class="{'is-disabled': maxDisabled}"
|
||||||
v-repeat-click="increase"
|
v-repeat-click="increase"
|
||||||
@mouseenter="activeInput(maxDisabled)"
|
|
||||||
@mouseleave="inactiveInput(maxDisabled)"
|
|
||||||
>
|
>
|
||||||
</span>
|
</span>
|
||||||
|
<el-input
|
||||||
|
v-model.number="currentValue"
|
||||||
|
@keydown.up.native="increase"
|
||||||
|
@keydown.down.native="decrease"
|
||||||
|
@blur="handleBlur"
|
||||||
|
:disabled="disabled"
|
||||||
|
:size="size"
|
||||||
|
>
|
||||||
|
<template slot="prepend" v-if="$slots.prepend">
|
||||||
|
<slot name="prepend"></slot>
|
||||||
|
</template>
|
||||||
|
<template slot="append" v-if="$slots.append">
|
||||||
|
<slot name="append"></slot>
|
||||||
|
</template>
|
||||||
|
</el-input>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script>
|
<script>
|
||||||
|
@ -50,29 +43,6 @@
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'ElInputNumber',
|
name: 'ElInputNumber',
|
||||||
props: {
|
|
||||||
step: {
|
|
||||||
type: Number,
|
|
||||||
default: 1
|
|
||||||
},
|
|
||||||
max: {
|
|
||||||
type: Number,
|
|
||||||
default: Infinity
|
|
||||||
},
|
|
||||||
min: {
|
|
||||||
type: Number,
|
|
||||||
default: 0
|
|
||||||
},
|
|
||||||
value: {
|
|
||||||
default: 0
|
|
||||||
},
|
|
||||||
disabled: Boolean,
|
|
||||||
size: String,
|
|
||||||
controls: {
|
|
||||||
type: Boolean,
|
|
||||||
default: true
|
|
||||||
}
|
|
||||||
},
|
|
||||||
directives: {
|
directives: {
|
||||||
repeatClick: {
|
repeatClick: {
|
||||||
bind(el, binding, vnode) {
|
bind(el, binding, vnode) {
|
||||||
|
@ -104,6 +74,29 @@
|
||||||
components: {
|
components: {
|
||||||
ElInput
|
ElInput
|
||||||
},
|
},
|
||||||
|
props: {
|
||||||
|
step: {
|
||||||
|
type: Number,
|
||||||
|
default: 1
|
||||||
|
},
|
||||||
|
max: {
|
||||||
|
type: Number,
|
||||||
|
default: Infinity
|
||||||
|
},
|
||||||
|
min: {
|
||||||
|
type: Number,
|
||||||
|
default: 0
|
||||||
|
},
|
||||||
|
value: {
|
||||||
|
default: 0
|
||||||
|
},
|
||||||
|
disabled: Boolean,
|
||||||
|
size: String,
|
||||||
|
controls: {
|
||||||
|
type: Boolean,
|
||||||
|
default: true
|
||||||
|
}
|
||||||
|
},
|
||||||
data() {
|
data() {
|
||||||
// correct the init value
|
// correct the init value
|
||||||
let value = this.value;
|
let value = this.value;
|
||||||
|
@ -116,8 +109,7 @@
|
||||||
value = this.max;
|
value = this.max;
|
||||||
}
|
}
|
||||||
return {
|
return {
|
||||||
currentValue: value,
|
currentValue: value
|
||||||
inputActive: false
|
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
|
@ -126,10 +118,9 @@
|
||||||
},
|
},
|
||||||
|
|
||||||
currentValue(newVal, oldVal) {
|
currentValue(newVal, oldVal) {
|
||||||
let value = Number(newVal);
|
if (newVal <= this.max && newVal >= this.min) {
|
||||||
if (value <= this.max && value >= this.min) {
|
this.$emit('change', newVal, oldVal);
|
||||||
this.$emit('change', value, oldVal);
|
this.$emit('input', newVal);
|
||||||
this.$emit('input', value);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -188,41 +179,19 @@
|
||||||
return (arg1 + arg2) / m;
|
return (arg1 + arg2) / m;
|
||||||
},
|
},
|
||||||
increase() {
|
increase() {
|
||||||
|
if (this.maxDisabled) return;
|
||||||
const value = this.value || 0;
|
const value = this.value || 0;
|
||||||
if (value + this.step > this.max || this.disabled) return;
|
if (value + this.step > this.max || this.disabled) return;
|
||||||
this.currentValue = this.accAdd(this.step, value);
|
this.currentValue = this.accAdd(this.step, value);
|
||||||
if (this.maxDisabled) {
|
|
||||||
this.inputActive = false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
decrease() {
|
decrease() {
|
||||||
|
if (this.minDisabled) return;
|
||||||
const value = this.value || 0;
|
const value = this.value || 0;
|
||||||
if (value - this.step < this.min || this.disabled) return;
|
if (value - this.step < this.min || this.disabled) return;
|
||||||
this.currentValue = this.accSub(value, this.step);
|
this.currentValue = this.accSub(value, this.step);
|
||||||
if (this.minDisabled) {
|
|
||||||
this.inputActive = false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
activeInput(disabled) {
|
handleBlur() {
|
||||||
if (!this.disabled && !disabled) {
|
this.currentValue = this.value;
|
||||||
this.inputActive = true;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
inactiveInput(disabled) {
|
|
||||||
if (!this.disabled && !disabled) {
|
|
||||||
this.inputActive = false;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
handleBlur(event) {
|
|
||||||
let value = Number(this.currentValue);
|
|
||||||
if (isNaN(value) || value > this.max || value < this.min) {
|
|
||||||
this.currentValue = this.value;
|
|
||||||
} else {
|
|
||||||
this.currentValue = value;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
handleInput(value) {
|
|
||||||
this.currentValue = value;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -23,9 +23,14 @@
|
||||||
color: #99A9BF;
|
color: #99A9BF;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
|
z-index: 1;
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
color: var(--color-primary);
|
color: var(--color-primary);
|
||||||
|
|
||||||
|
&:not(.is-disabled) ~ .el-input .el-input__inner:not(.is-disabled) {
|
||||||
|
border-color: var(--input-focus-border);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@when disabled {
|
@when disabled {
|
||||||
|
|
|
@ -38,22 +38,14 @@ describe('InputNumber', () => {
|
||||||
let input = vm.$el.querySelector('input');
|
let input = vm.$el.querySelector('input');
|
||||||
let btnDecrease = vm.$el.querySelector('.el-input-number__decrease');
|
let btnDecrease = vm.$el.querySelector('.el-input-number__decrease');
|
||||||
|
|
||||||
triggerEvent(btnDecrease, 'mouseenter');
|
|
||||||
triggerEvent(btnDecrease, 'mousedown');
|
triggerEvent(btnDecrease, 'mousedown');
|
||||||
triggerEvent(document, 'mouseup');
|
triggerEvent(document, 'mouseup');
|
||||||
|
|
||||||
setTimeout(_ => {
|
vm.$nextTick(_ => {
|
||||||
expect(vm.$el.querySelector('.el-input.is-active')).to.exist;
|
|
||||||
expect(vm.value).to.be.equal(4);
|
expect(vm.value).to.be.equal(4);
|
||||||
expect(input.value).to.be.equal('4');
|
expect(input.value).to.be.equal('4');
|
||||||
|
done();
|
||||||
triggerEvent(btnDecrease, 'mouseleave');
|
});
|
||||||
|
|
||||||
vm.$nextTick(_ => {
|
|
||||||
expect(vm.$el.querySelector('.el-input.is-active')).to.not.exist;
|
|
||||||
done();
|
|
||||||
});
|
|
||||||
}, 300);
|
|
||||||
});
|
});
|
||||||
it('increase', done => {
|
it('increase', done => {
|
||||||
vm = createVue({
|
vm = createVue({
|
||||||
|
@ -74,11 +66,11 @@ describe('InputNumber', () => {
|
||||||
triggerEvent(btnIncrease, 'mousedown');
|
triggerEvent(btnIncrease, 'mousedown');
|
||||||
triggerEvent(document, 'mouseup');
|
triggerEvent(document, 'mouseup');
|
||||||
|
|
||||||
setTimeout(_ => {
|
vm.$nextTick(_ => {
|
||||||
expect(vm.value).to.be.equal(2.5);
|
expect(vm.value).to.be.equal(2.5);
|
||||||
expect(input.value).to.be.equal('2.5');
|
expect(input.value).to.be.equal('2.5');
|
||||||
done();
|
done();
|
||||||
}, 100);
|
});
|
||||||
});
|
});
|
||||||
it('disabled', done => {
|
it('disabled', done => {
|
||||||
vm = createVue({
|
vm = createVue({
|
||||||
|
@ -100,19 +92,19 @@ describe('InputNumber', () => {
|
||||||
triggerEvent(btnDecrease, 'mousedown');
|
triggerEvent(btnDecrease, 'mousedown');
|
||||||
triggerEvent(document, 'mouseup');
|
triggerEvent(document, 'mouseup');
|
||||||
|
|
||||||
triggerEvent(btnIncrease, 'mousedown');
|
vm.$nextTick(_ => {
|
||||||
triggerEvent(document, 'mouseup');
|
|
||||||
|
|
||||||
setTimeout(_ => {
|
|
||||||
expect(vm.value).to.be.equal(2);
|
expect(vm.value).to.be.equal(2);
|
||||||
expect(input.value).to.be.equal('2');
|
expect(input.value).to.be.equal('2');
|
||||||
|
|
||||||
setTimeout(_ => {
|
triggerEvent(btnIncrease, 'mousedown');
|
||||||
|
triggerEvent(document, 'mouseup');
|
||||||
|
|
||||||
|
vm.$nextTick(_ => {
|
||||||
expect(vm.value).to.be.equal(2);
|
expect(vm.value).to.be.equal(2);
|
||||||
expect(input.value).to.be.equal('2');
|
expect(input.value).to.be.equal('2');
|
||||||
done();
|
done();
|
||||||
}, 100);
|
});
|
||||||
}, 100);
|
});
|
||||||
});
|
});
|
||||||
it('step', done => {
|
it('step', done => {
|
||||||
vm = createVue({
|
vm = createVue({
|
||||||
|
@ -134,19 +126,19 @@ describe('InputNumber', () => {
|
||||||
triggerEvent(btnIncrease, 'mousedown');
|
triggerEvent(btnIncrease, 'mousedown');
|
||||||
triggerEvent(document, 'mouseup');
|
triggerEvent(document, 'mouseup');
|
||||||
|
|
||||||
setTimeout(_ => {
|
vm.$nextTick(_ => {
|
||||||
expect(vm.value).to.be.equal(8.2);
|
expect(vm.value).to.be.equal(8.2);
|
||||||
expect(input.value).to.be.equal('8.2');
|
expect(input.value).to.be.equal('8.2');
|
||||||
|
|
||||||
triggerEvent(btnDecrease, 'mousedown');
|
triggerEvent(btnDecrease, 'mousedown');
|
||||||
triggerEvent(document, 'mouseup');
|
triggerEvent(document, 'mouseup');
|
||||||
|
|
||||||
setTimeout(_ => {
|
vm.$nextTick(_ => {
|
||||||
expect(vm.value).to.be.equal(5);
|
expect(vm.value).to.be.equal(5);
|
||||||
expect(input.value).to.be.equal('5');
|
expect(input.value).to.be.equal('5');
|
||||||
done();
|
done();
|
||||||
}, 100);
|
});
|
||||||
}, 100);
|
});
|
||||||
});
|
});
|
||||||
it('min', done => {
|
it('min', done => {
|
||||||
vm = createVue({
|
vm = createVue({
|
||||||
|
@ -181,11 +173,11 @@ describe('InputNumber', () => {
|
||||||
triggerEvent(btnDecrease, 'mousedown');
|
triggerEvent(btnDecrease, 'mousedown');
|
||||||
triggerEvent(document, 'mouseup');
|
triggerEvent(document, 'mouseup');
|
||||||
|
|
||||||
setTimeout(_ => {
|
vm.$nextTick(_ => {
|
||||||
expect(vm.value).to.be.equal(6);
|
expect(vm.value).to.be.equal(6);
|
||||||
expect(input.value).to.be.equal('6');
|
expect(input.value).to.be.equal('6');
|
||||||
done();
|
done();
|
||||||
}, 100);
|
});
|
||||||
});
|
});
|
||||||
it('max', done => {
|
it('max', done => {
|
||||||
vm = createVue({
|
vm = createVue({
|
||||||
|
@ -220,11 +212,11 @@ describe('InputNumber', () => {
|
||||||
triggerEvent(btnIncrease, 'mousedown');
|
triggerEvent(btnIncrease, 'mousedown');
|
||||||
triggerEvent(document, 'mouseup');
|
triggerEvent(document, 'mouseup');
|
||||||
|
|
||||||
setTimeout(_ => {
|
vm.$nextTick(_ => {
|
||||||
expect(vm.value).to.be.equal(8);
|
expect(vm.value).to.be.equal(8);
|
||||||
expect(input.value).to.be.equal('8');
|
expect(input.value).to.be.equal('8');
|
||||||
done();
|
done();
|
||||||
}, 100);
|
});
|
||||||
});
|
});
|
||||||
it('controls', () => {
|
it('controls', () => {
|
||||||
vm = createVue({
|
vm = createVue({
|
||||||
|
@ -242,4 +234,30 @@ describe('InputNumber', () => {
|
||||||
expect(vm.$el.querySelector('.el-input-number__decrease')).to.not.exist;
|
expect(vm.$el.querySelector('.el-input-number__decrease')).to.not.exist;
|
||||||
expect(vm.$el.querySelector('.el-input-number__increase')).to.not.exist;
|
expect(vm.$el.querySelector('.el-input-number__increase')).to.not.exist;
|
||||||
});
|
});
|
||||||
|
it('event:change', done => {
|
||||||
|
vm = createVue({
|
||||||
|
template: `
|
||||||
|
<el-input-number v-model="value" ref="input">
|
||||||
|
</el-input-number>
|
||||||
|
`,
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
value: 1.5
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}, true);
|
||||||
|
|
||||||
|
let btnIncrease = vm.$el.querySelector('.el-input-number__increase');
|
||||||
|
const spy = sinon.spy();
|
||||||
|
|
||||||
|
vm.$refs.input.$on('change', spy);
|
||||||
|
|
||||||
|
triggerEvent(btnIncrease, 'mousedown');
|
||||||
|
triggerEvent(document, 'mouseup');
|
||||||
|
|
||||||
|
vm.$nextTick(_ => {
|
||||||
|
expect(spy.withArgs(2.5, 1.5).calledOnce).to.be.true;
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue