随着 Vue 越来越火热, 相关组件库也非常多啦, 只用轮子怎么够, 还是要造起来!!!
1、概述
Vue组件开发的API:props、events和slots
2、组件代码
github地址:https://github.com/MengFangui/VueInputNumber
效果:
(1)index.html
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8" /> <title>数字输入框组件</title> </head> <body> <div id="app"> <!--数字输入框组件命名为:input-number--> <!--数字输入框组件默认值为5,最大值为10,最小值为0--> <input-number v-model='value' :max='10' :min='0'></input-number> </div> <script src="https://cdn.bootcss.com/vue/2.5.9/vue.min.js"></script> <script src="js/input-number.js" type="text/javascript" charset="utf-8"></script> <script src="js/index.js" type="text/javascript" charset="utf-8"></script> </body> </html>
(2)input-number.js
//验证输入值是否为数字 function isValueNumber(value) { return(/(^-?[0-9]+\.{1}\d+$)|(^-?[1-9]*$)|(^-?0{1}$)/).test(value + ''); } Vue.component('input-number', { //模板 template: ` <div class="input-number"> <input type="text" :value="currentValue" @change="handleChange" /> <button @click="handleDown" :disabled="currentValue <= min">-</button> <button @click="handleUp" :disabled="currentValue >= max">+</button> </div> `, //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开发数字输入框组件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
本文向大家介绍Vue数字输入框组件的使用方法,包括了Vue数字输入框组件的使用方法的使用技巧和注意事项,需要的朋友参考一下 最近在通过《Vue.js实战》系统学习Vue,虽然在项目中已多次使用Vue进行开发,但是对于一些非常基础性的知识点还不是很了解,因此这次通过结合数字输入框组件实战来谈谈简单的组件开发。 源代码:数字输入框组件 项目整体结构 ├── src 项目代码 │ ├── common
本文向大家介绍vue实现验证码输入框组件,包括了vue实现验证码输入框组件的使用技巧和注意事项,需要的朋友参考一下 先来看波完成效果图 需求 输入4位或6位短信验证码,输入完成后收起键盘 实现步骤 第一步 布局排版 使用li元素来模拟输入框的显示,没有别的目的,就只是为了语义化,当然你也可以使用其他任意一个元素来模拟,比如div。 使用label标签的好处在于它可以跟input的click事件
mui提供了数字输入框控件,可直接输入数字,也可以点击“+”、“-”按钮变换当前数值;默认numbox控件dom结构比较简单,如下: <div class="mui-numbox"> <!-- "-"按钮,点击可减小当前数值 --> <button class="mui-btn mui-numbox-btn-minus" type="button">-</button> <inp
通过在一个文本输入框<input>的任一侧添加文本、按钮以及按钮组,很容易扩展表单控件。 基本示例 把一个附加内容或按钮放在输入框的任一侧。你可以把它们同时放在输入框的两侧。我们不支持在同一侧放多个附加内容,同样也不支持多个表单控件放在一个输入框组中。 <div class="input-group"> <span class="input-group-addon" id="basic-ad
本文向大家介绍深入浅析Vue组件开发,包括了深入浅析Vue组件开发的使用技巧和注意事项,需要的朋友参考一下 前言 这里讲的主要是想谈谈基于Vue的一个组件开发。不得不说的一点就是,在实际的Vue项目中,页面中每一个小块都是由一个个组件(.vue文件)组成,经过抽离后,然后再合并一起组成一个页面。由于上家公司我负责多的是可视化这一块的开发,这边我也将带着大家进行一个Vue项目中的可视化组件的开发,这
本文向大家介绍关于Vue组件库开发详析,包括了关于Vue组件库开发详析的使用技巧和注意事项,需要的朋友参考一下 前言 2017年是Vue.js大爆发的一年,React迎来了一个强有力的竞争对手,王者地位受到挑战(撰写此文时github上Vue与React的star数量已逼近)。我们团队这一年有十多个大型项目采用了Vue技术栈,在开发效率、页面性能、可维护性等方面都有不错的收效。 我们希望把这些项目