InputNumber 数字输入框

数字输入框组件。

何时使用

当需要获取标准数值时。

基本用法

只需要在 d-input-number 元素中使用 v-model 绑定变量即可,变量的初始值即为默认值。
<template>
  <div>
    <d-input-number v-model="num" @change="onChange" placeholder="请输入"></d-input-number>
  </div>
</template>
<script>
import { defineComponent, ref } from 'vue';

export default defineComponent({
  setup(props) {
    const num = ref(0);
    const onChange = (newVal, oldVal) => {
      console.log(newVal, oldVal);
    };
    return {
      num,
      onChange,
    };
  },
});
</script>

禁用状态

disabled 属性设置为 true 即可禁用整个组件。
<template>
  <div>
    <d-input-number v-model="num" disabled></d-input-number>
  </div>
</template>
<script>
import { defineComponent, ref } from 'vue';

export default defineComponent({
  setup(props) {
    const num = ref(0);
    return {
      num,
    };
  },
});
</script>

数值范围

如果你需要控制数值在某一范围内,可以设置 min 属性和 max 属性。当给组件设置的初始值大于 max 属性值时会自动被重置为 max属性值,小于 min 属性值时会自动被重置为 min属性值。
<template>
  <div>
    <d-input-number v-model="num" :min="1" :max="5"></d-input-number>
  </div>
</template>
<script>
import { defineComponent, ref } from 'vue';

export default defineComponent({
  setup(props) {
    const num = ref(0);
    return {
      num,
    };
  },
});
</script>

步数

设置 step 属性可以控制步长。
<template>
  <div>
    <d-input-number v-model="num" :step="3"></d-input-number>
  </div>
</template>
<script>
import { defineComponent, ref } from 'vue';

export default defineComponent({
  setup(props) {
    const num = ref(3);
    return {
      num,
    };
  },
});
</script>

精度

precision属性可以控制数值精度。
<template>
  <div>
    <d-input-number v-model="num" :precision="2" :step="0.1"></d-input-number>
  </div>
</template>
<script>
import { defineComponent, ref } from 'vue';

export default defineComponent({
  setup(props) {
    const num = ref(1);
    return {
      num,
    };
  },
});
</script>

尺寸

Large
Middle
Small
提供了 lg、md、sm 三种尺寸的数字输入框,默认尺寸为 md。
<template>
  <div>
    <div class="space">Large</div>
    <d-input-number v-model="num1" :size="'lg'"></d-input-number>
    <div class="space">Middle</div>
    <d-input-number v-model="num2" :size="'md'"></d-input-number>
    <div class="space">Small</div>
    <d-input-number v-model="num3" :size="'sm'"></d-input-number>
  </div>
</template>
<script>
import { defineComponent, ref } from 'vue';

export default defineComponent({
  setup() {
    const num1 = ref(1);
    const num2 = ref(2);
    const num3 = ref(3);
    return {
      num1,
      num2,
      num3,
    };
  },
});
</script>
<style>
.space {
  padding: 5px 0;
  font-size: 16px;
}
</style>

正则限制

reg
regStr
允许传入正则或正则字符串限制输入,输入时会优先匹配传入的正则,不输入则不限制。
<template>
  <div>
    <div class="space">reg</div>
    <d-input-number v-model="num1" :reg="reg"></d-input-number>
    
    <div class="space">regStr</div>
    <d-input-number v-model="num2" :reg="regStr"></d-input-number>
  </div>
</template>
<script>
import { defineComponent, ref } from 'vue';

export default defineComponent({
  setup() {
    const reg = /^(-|\+)?\d*$/;
    const regStr = '^(-|\\+)*\\d*$';
    const num1 = ref(1);
    const num2 = ref(2);
    return {
      num1,
      num2,
      reg,
      regStr
    };
  },
});
</script>
<style>
.space {
  padding: 5px 0;
  font-size: 16px;
}
</style>

InputNumber 参数

参数名类型默认值说明跳转 Demo
v-modelnumber--可选,文本框的值基本用法
stepnumber1可选,步数步数
placeholderstring--可选,文本框 placeholder基本用法
maxnumberInfinity可选,输入框的最大值 max数值范围
minnumber-Infinity可选,输入框的最小值 min数值范围
disabledbooleanfalse可选,文本框是否被禁用禁用状态
precisionnumber--可选,数值精度精度
sizeISize'md'可选,文本框尺寸尺寸
regRegExp| string--可选,用于限制输入的正则或正则字符串正则限制

InputNumber 事件

事件名回调参数说明
changeFunction(currentVal: number | undefined, oldVal:number | undefined)绑定值被改变时触发
blurFunction(event: Event)在 Input 失去焦点时触发
focusFunction(event: Event)在 Input 获得焦点时触发
inputFunction(currentValue: number | undefined)在 Input 获得输入时触发

InputNumber 方法

方法名类型说明
focus() => void使 Input 获得焦点
blur() => void使 Input 失去焦点
select() => void选中 Input 中的内容

InputNumber 类型定义

ISize

type ISize = 'lg' | 'md' | 'sm';
Contributors