value数字 vue_基于Vue开发数字输入框组件

本文详细介绍了如何基于Vue框架创建一个数字输入框组件,涉及props、events和slots的使用,并提供了代码示例,包括验证输入、双向数据绑定和父子组件通信。适合Vue初学者和组件开发者参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

随着 vue 越来越火热, 相关组件库也非常多啦, 只用轮子怎么够, 还是要造起来!!!

1、概述

vue组件开发的api:props、events和slots

2、组件代码

效果:

(1)index.html

数字输入框组件

(2)input-number.js

//验证输入值是否为数字

function isvaluenumber(value) {

return(/(^-?[0-9]+\.{1}\d+$)|(^-?[1-9]*$)|(^-?0{1}$)/).test(value + '');

}

vue.component('input-number', {

//模板

template: `

-

+

`,

//props实现与父组件的通信(父组件-->子组件)

//对每个props进行校验,props的值可以是数组,也可以是对象

props: {

max: {

//必须是数字类型

type: number,

//默认值为infinity

default: infinity

},

min: {

type: number,

default: -infinity

},

value: {

type: number,

default: 0

}

},

//vue组件为单向数据流,声明data来引用父组件的value,在组件内部维护currentvalue

data: function() {

return {

currentvalue: this.value

}

},

//监听:与父组件通信 (子组件-->父组件)

watch: {

currentvalue: function(val) {

//使用v-model改变value

//this指向当前组件实例

this.$emit('input', val)

}

// ,

//本示例未使用自定义函数,使用了v-mode input函数来更新value

// value: function(val) {

// //自定义事件on-change,告知父组件数字输入框值有所改变

// this.$emit('on-change', val)

// }

},

methods: {

//父组件传递过来的值可能不符合条件(大于最大值,小于最小值)

updatevalue: function(val) {

if(val > this.max) {

val = this.max;

}

if(val < this.min) {

val = this.min;

}

this.currentvalue = val;

},

handledown: function() {

if(this.currentvalue <= this.min) {

return;

}

this.currentvalue -= 1;

},

handleup: function() {

if(this.currentvalue >= this.max) {

return;

}

this.currentvalue += 1;

},

handlechange: function(event) {

var val = event.target.value.trim();

var max = this.max;

var min = this.min;

if(isvaluenumber(val)) {

val = number(val);

this.currentvalue = val;

if(val > max) {

this.current = max;

}

if(val < min) {

this.current = min;

}

} else {

//如果输入的不是数字,将输入的内容重置为之前的currentvalue

event.target.value = this.currentvalue;

}

}

},

//初始化

mounted: function() {

this.updatevalue(this.value);

}

})

(3)index.js

var app = new vue({

el: '#app',

data: {

//数字输入框组件默认值为5(父组件设置初始化值)

value: 5

}

})

总结

以上所述是小编给大家介绍的基于vue开发数字输入框组件,希望对大家有所帮助

希望与广大网友互动??

点此进行留言吧!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值