gui-step-box.vue 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. <template>
  2. <view class="gui-flex gui-rows gui-nowrap gui-align-items-center"
  3. :style="{width:width}">
  4. <view hover-class="gui-tap">
  5. <text class="gui-block-text gui-text-center gui-number-box-button" @tap.stop="reduce"
  6. :style="buttonStyle">-</text>
  7. </view>
  8. <input class="gui-number-box-input" :disabled="disabled"
  9. v-model="inputNumber" type="digit" @blur="inputval"
  10. :style="inputStyle" />
  11. <view hover-class="gui-tap">
  12. <text class="gui-block-text gui-text-center gui-number-box-button" @tap.stop="add"
  13. :style="buttonStyle">+</text>
  14. </view>
  15. </view>
  16. </template>
  17. <script>
  18. export default {
  19. name : "gui-step-box",
  20. props : {
  21. width : { type : String, default : '200rpx' },
  22. value : { type : Number, default : 0 },
  23. step : { type : Number, default : 1 },
  24. maxNum : { type : Number, default : 9999 },
  25. minNum : { type : Number, default : 0 },
  26. buttonStyle : { type : String, default : 'width:66rpx; font-size:38rpx; color:rgba(69, 90, 100, 0.6);' },
  27. inputStyle : { type : String, default : 'line-height:58rpx; height:58rpx; font-size:26rpx; color:#2B2E3D; background-color:#F6F7F8; border-radius:8rpx;'},
  28. disabled : { type : Boolean, default : false },
  29. index : { type : Number, default : 0 },
  30. datas : { type : Array, default : function () {
  31. return [];
  32. }},
  33. decimal : { type : Number, default:2}
  34. },
  35. data() {
  36. return {
  37. inputNumber : 0,
  38. callbackNumber : 0
  39. }
  40. },
  41. created:function(){
  42. this.inputNumber = Number(this.value);
  43. },
  44. watch:{
  45. value : function(val, vo){
  46. this.inputNumber = Number(val);
  47. },
  48. inputNumber :function(val, vo){
  49. if(val == ''){
  50. return ;
  51. }
  52. val = Number(val);
  53. if(isNaN(val)){
  54. setTimeout(()=>{this.inputNumber = Number(vo);}, 200); return;
  55. }
  56. var newVal = this.decimalVal(val);
  57. if(newVal != val){
  58. setTimeout(()=>{this.inputNumber = Number(newVal);}, 200);
  59. return;
  60. }
  61. if(val > this.maxNum){
  62. setTimeout(()=>{this.inputNumber = this.maxNum;}, 200);
  63. return ;
  64. }
  65. if(val < this.minNum){
  66. setTimeout(()=>{this.inputNumber = this.minNum;}, 200);
  67. return ;
  68. }
  69. }
  70. },
  71. methods : {
  72. add : function(){
  73. var newVal = Number(this.inputNumber) + Number(this.step);
  74. newVal = this.decimalVal(newVal);
  75. if(newVal > this.maxNum){return ;}
  76. this.inputNumber = Number(newVal);
  77. setTimeout(()=>{
  78. this.$emit('change', [this.inputNumber, this.index, this.datas]);
  79. }, 300);
  80. },
  81. reduce : function () {
  82. var newVal = Number(this.inputNumber) - Number(this.step);
  83. newVal = this.decimalVal(newVal);
  84. if(newVal < this.minNum){return ;}
  85. this.inputNumber = newVal;
  86. setTimeout(()=>{
  87. this.$emit('change', [this.inputNumber, this.index, this.datas]);
  88. }, 300);
  89. },
  90. inputval : function (e) {
  91. this.inputNumber = e.detail.value;
  92. setTimeout(()=>{
  93. this.$emit('change', [this.inputNumber, this.index, this.datas]);
  94. }, 300);
  95. },
  96. decimalVal : function (val) {
  97. var isDecimal = String(val).indexOf(".");
  98. if(isDecimal != -1){
  99. val = val.toFixed(this.decimal);
  100. var valArr = String(val).split('.');
  101. if(valArr[1].length > this.decimal){
  102. valArr[1] = valArr[1].substr(0, this.decimal);
  103. val = Number(valArr.join('.'));
  104. }
  105. }
  106. return val ;
  107. }
  108. }
  109. }
  110. </script>
  111. <style scoped>
  112. /* #ifndef APP-NVUE */
  113. .gui-number-box-input{text-align:center; width:500rpx;}
  114. .gui-number-box-button{overflow:hidden; flex-shrink:0;}
  115. /* #endif */
  116. /* #ifdef APP-NVUE */
  117. .gui-number-box-input{text-align:center; width:50rpx; flex:1;}
  118. .gui-number-box-button{overflow:hidden;}
  119. /* #endif */
  120. </style>