Vue数字输入框组件示例代码详解


Posted in Javascript onJanuary 15, 2020

数字输入框组件

实现功能:只允许输入数字(包括小数)、允许设置初始值、最大值、最小值。

为了方便,这里选用Vue的 cli-service

Vue数字输入框组件示例代码详解

实现快速原型开发

首先template部分代码

<template>
 <div class="demo">
  <input-number v-model="value" :max="10" :min="0"></input-number>
 </div>
</template>

这部分没有什么特别说明的,分别传入 value、max、min 作为子组件的原始值最大值和最小值。在子组件中用 props 接收,独立组件,对每个传入的prop进行类型验证

主要JS部分代码

<script>
import Vue from 'vue'
Vue.component('input-number',{
 props: {
  value: {
   type: Number,
   default: 0
  },
  max: {
   type: Number,
   default: Infinity
  },
  min: {
   type: Number,
   default: -Infinity
  }
 },
 data() {
  return {
   currentValue: this.value
  }
 },
 render(cr) {
  let _this = this
  ...
 }
})
export default {
 data() {
  return {
   value: 5
  }
 }
}
</script>

在这里不能使用字符串的方式定义组件模板,所以使用 render() 函数的方式

render(cr) {
 let _this = this
 return cr('div',{'class': 'input-number'},[
  cr('button',{'class': {'down-btn':true,'dis':this.currentValue<=this.min},on: {click: _this.handleDown},},['-']),
  cr('input',{'class': 'change-input',domProps: {value: _this.currentValue}, on: {change: _this.handleChange}}),
  cr('button',{'class': {'down-btn':true,'dis':this.currentValue>=this.max},on: {click: _this.handleUp},},['+']),
 ])
}

定义 watch 和 methods

watch: {
 value(val) {
  this.updateValue(val)
 },
 currentValue(val) {
  this.$emit('input', val)
  this.$emit('on-change', val)
 }
},
methods: {
 updateValue(val) {
  if(val > this.max) val = this.max
  if(val < this.min) val = this.min
  this.currentValue = val
 },
 handleDown() {
  if(this.currentValue<=this.min) return
  this.currentValue-=1
 },
 handleUp() {
  if(this.currentValue>=this.max) return
  this.currentValue+=1
 },
 handleChange(ev) {
  let val = ev.target.value.trim()
  let max = this.max
  let min = this.min
  if(this.isValueNumber(val)) {
   val = Number(val)
   this.currentValue = val
   if(val > max) {
    this.currentValue = max
   } else if(val < min) {
    this.currentValue = min
   }
  }else {
   ev.target.value = this.currentValue
  }
 },
 isValueNumber(val) {
  return (/(^-?[0-9]+\.{1}\d+$)|(^-?[1-9][0-9]*$)|(^-?0{1}$)/).test(val+'')
 }
}

最后是Less部分代码

<style lang="less">
* {
 box-sizing: border-box;
}
.demo {
 width: 200px;
 margin: 0 auto;
}
.input-number {
 width: 100%;
 display: flex;
 height: 40px;
 align-items: center;
 justify-content: space-between;
 .down-btn,.up-btn {
  font-size: 18px;
  width: 40px;
  height: 40px;
  background-color: #f5f7fa;
  color: #606266;
  border: 1px solid #dcdfe6;
  border-radius: 4px 0 0 4px;
  cursor: pointer;
  outline: none;
  &.up-btn {
   border-radius: 0 4px 4px 0;
  }
  &.dis {
   cursor: not-allowed;
  }
 }
 .change-input {
  flex: 1;
  max-width: 100px;
  outline: none;
  border: none;
  text-align: center;
  height: 40px;
 }
}
</style>

总结

以上所述是小编给大家介绍的Vue数字输入框组件示例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
默认让页面的第一个控件选中的javascript代码
Dec 26 Javascript
jQuery学习5 jQuery事件模型
Feb 07 Javascript
node.js中的querystring.stringify方法使用说明
Dec 10 Javascript
常见的javascript跨域通信方法
Dec 31 Javascript
在Node.js中使用Javascript Generators详解
May 05 Javascript
利用Angularjs中模块ui-route管理状态的方法
Dec 27 Javascript
关于axios返回空对象的问题解决
Apr 04 Javascript
js实现鼠标拖拽多选功能示例
Aug 01 Javascript
jquery获取transform里的值实现方法
Dec 12 jQuery
浅析java线程中断的办法
Jul 29 Javascript
详解keep-alive + vuex 让缓存的页面灵活起来
Apr 19 Javascript
JS实现单张或多张图片持续无缝滚动的示例代码
May 10 Javascript
Vue v-bind动态绑定class实例方法
Jan 15 #Javascript
JS 事件机制完整示例分析
Jan 15 #Javascript
JS实现滑动插件
Jan 15 #Javascript
JS实现滑动导航效果
Jan 14 #Javascript
解决 window.onload 被覆盖的问题方法
Jan 14 #Javascript
vue quill editor 使用富文本添加上传音频功能
Jan 14 #Javascript
JavaScript事件冒泡机制原理实例解析
Jan 14 #Javascript
You might like
关于使用key/value数据库redis和TTSERVER的心得体会
2013/06/28 PHP
PHP cdata 处理(详细介绍)
2013/07/05 PHP
php封装的mongodb操作类代码
2017/08/06 PHP
function, new function, new Function之间的区别
2007/03/08 Javascript
学习并汇集javascript匿名函数
2010/11/25 Javascript
jQuery学习总结之元素的相对定位和选择器(持续更新)
2011/04/26 Javascript
JS取文本框中最小值的简单实例
2013/11/29 Javascript
浅谈JavaScript实现面向对象中的类
2014/12/09 Javascript
JS实现跟随鼠标的链接文字提示框效果
2015/08/06 Javascript
Bootstrap4一次重大更新 几乎涉及每行代码
2016/05/16 Javascript
JS 清除字符串数组中,重复元素的实现方法
2016/05/24 Javascript
jQuery File Upload文件上传插件使用详解
2016/12/06 Javascript
js返回顶部实例分享
2016/12/21 Javascript
jQuery实现base64前台加密解密功能详解
2017/08/29 jQuery
fetch 使用及如何接收JS传值
2017/11/11 Javascript
AngularJs 禁止模板缓存的方法
2017/11/28 Javascript
原生JS实现自定义下拉单选选择框功能
2018/10/12 Javascript
js控制随机数生成概率代码实例
2019/03/21 Javascript
vue 强制组件重新渲染(重置)的两种方案
2019/10/29 Javascript
简单介绍Python中的floor()方法
2015/05/15 Python
Python cookbook(数据结构与算法)在字典中将键映射到多个值上的方法
2018/02/18 Python
python 使用pandas计算累积求和的方法
2019/02/08 Python
python使用列表的最佳方案
2020/08/12 Python
美国高端婴童品牌:Hanna Andersson
2016/10/30 全球购物
意大利运动服减价商店:ScontoSport
2020/03/10 全球购物
商务日语毕业生自荐信范文
2013/11/14 职场文书
计算机个人求职信范例
2014/01/24 职场文书
《长相思》听课反思
2014/04/10 职场文书
诉前财产保全担保书
2014/05/20 职场文书
2014优秀党员事迹材料
2014/08/14 职场文书
2016年员工政治思想表现评语
2015/12/02 职场文书
《全神贯注》教学反思
2016/02/22 职场文书
自荐信大全
2019/03/21 职场文书
《鲁班学艺》读后感3篇
2019/11/27 职场文书
MySQL之select、distinct、limit的使用
2021/11/11 MySQL
详解Python中的for循环
2022/04/30 Python