first commit
This commit is contained in:
173
components/uni-number-box.vue
Normal file
173
components/uni-number-box.vue
Normal file
@ -0,0 +1,173 @@
|
||||
<template>
|
||||
<view class="uni-numbox">
|
||||
<view class="uni-numbox-minus" :class="{'uni-numbox-disabled': disableSubtract}" @click="_calcValue('subtract')">-</view>
|
||||
<input class="uni-numbox-value" type="number" :disabled="disabled" :value="inputValue" @blur="_onBlur">
|
||||
<view class="uni-numbox-plus" :class="{'uni-numbox-disabled': disableAdd}" @click="_calcValue('add')">+</view>
|
||||
</view>
|
||||
</template>
|
||||
<script>
|
||||
export default {
|
||||
name: 'uni-number-box',
|
||||
props: {
|
||||
value: {
|
||||
type: Number,
|
||||
default: 0
|
||||
},
|
||||
min: {
|
||||
type: Number,
|
||||
default: -Infinity
|
||||
},
|
||||
max: {
|
||||
type: Number,
|
||||
default: Infinity
|
||||
},
|
||||
step: {
|
||||
type: Number,
|
||||
default: 1
|
||||
},
|
||||
disabled: {
|
||||
type: Boolean,
|
||||
default: false
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
inputValue: this.value
|
||||
}
|
||||
},
|
||||
computed: {
|
||||
disableSubtract() {
|
||||
return this.value <= this.min
|
||||
},
|
||||
disableAdd() {
|
||||
return this.value >= this.max
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
value(val) {
|
||||
this.inputValue = val;
|
||||
},
|
||||
inputValue(val) {
|
||||
this.$emit('change', val);
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
_calcValue(type) {
|
||||
const scale = this._getDecimalScale();
|
||||
let value = this.inputValue * scale;
|
||||
let step = this.step * scale;
|
||||
|
||||
if (type === 'subtract') {
|
||||
value -= step
|
||||
} else if (type === 'add') {
|
||||
value += step
|
||||
}
|
||||
if (value < this.min || value > this.max) {
|
||||
return
|
||||
}
|
||||
this.inputValue = value / scale;
|
||||
},
|
||||
_getDecimalScale() {
|
||||
let scale = 1;
|
||||
// 浮点型
|
||||
if (~~this.step !== this.step) {
|
||||
scale = Math.pow(10, (this.step + '').split('.')[1].length);
|
||||
}
|
||||
return scale;
|
||||
},
|
||||
_onBlur(event) {
|
||||
let value = event.detail.value;
|
||||
if (!value) {
|
||||
this.inputValue = 0;
|
||||
return
|
||||
}
|
||||
value = +value;
|
||||
if (value > this.max) {
|
||||
value = this.max;
|
||||
} else if (value < this.min) {
|
||||
value = this.min
|
||||
}
|
||||
this.inputValue = value
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style>
|
||||
.uni-numbox {
|
||||
display: inline-flex;
|
||||
flex-direction: row;
|
||||
justify-content: flex-start;
|
||||
height: 70upx;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.uni-numbox::after {
|
||||
content: '';
|
||||
position: absolute;
|
||||
transform-origin: center;
|
||||
box-sizing: border-box;
|
||||
pointer-events: none;
|
||||
top: -50%;
|
||||
left: -50%;
|
||||
right: -50%;
|
||||
bottom: -50%;
|
||||
border: 1px solid #c8c7cc;
|
||||
transform: scale(.5);
|
||||
}
|
||||
|
||||
.uni-numbox-minus,
|
||||
.uni-numbox-plus {
|
||||
margin: 0;
|
||||
background-color: #f9f9f9;
|
||||
width: 80upx;
|
||||
height: 100%;
|
||||
line-height: 70upx;
|
||||
text-align: center;
|
||||
color: #555555;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.uni-numbox-minus {
|
||||
border-right: none;
|
||||
border-top-left-radius: 6upx;
|
||||
border-bottom-left-radius: 6upx;
|
||||
}
|
||||
|
||||
.uni-numbox-plus {
|
||||
border-left: none;
|
||||
border-top-right-radius: 6upx;
|
||||
border-bottom-right-radius: 6upx;
|
||||
}
|
||||
|
||||
.uni-numbox-value {
|
||||
position: relative;
|
||||
background-color: #ffffff;
|
||||
width: 80upx;
|
||||
height: 100%;
|
||||
text-align: center;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
.uni-numbox-value::after {
|
||||
content: '';
|
||||
position: absolute;
|
||||
transform-origin: center;
|
||||
box-sizing: border-box;
|
||||
pointer-events: none;
|
||||
top: -50%;
|
||||
left: -50%;
|
||||
right: -50%;
|
||||
bottom: -50%;
|
||||
border-style: solid;
|
||||
border-color: #cccccc;
|
||||
border-left-width: 1px;
|
||||
border-right-width: 1px;
|
||||
border-top-width: 0;
|
||||
border-bottom-width: 0;
|
||||
transform: scale(.5);
|
||||
}
|
||||
|
||||
.uni-numbox-disabled {
|
||||
color: #c0c0c0;
|
||||
}
|
||||
</style>
|
||||
Reference in New Issue
Block a user