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 相关文章推荐
js利用Array.splice实现Array的insert/remove
Jan 13 Javascript
JavaScript图片放大技术(放大镜)实现代码分享
Nov 14 Javascript
javascript使用switch case实现动态改变超级链接文字及地址
Dec 16 Javascript
jQuery实现图片向左向右切换效果的简单实例
May 18 Javascript
jQuery数据检索中根据关键字快速定位GridView指定行的实现方法
Jun 08 Javascript
微信小程序 MD5加密登录密码详解及实例代码
Jan 12 Javascript
在 Typescript 中使用可被复用的 Vue Mixin功能
Apr 17 Javascript
深入理解Vue router的部分高级用法
Aug 15 Javascript
Vue开发实现吸顶效果的示例代码
Aug 21 Javascript
浅谈JavaScript节流和防抖函数
Aug 25 Javascript
Nuxt.js的路由跳转操作(页面跳转nuxt-link)
Nov 06 Javascript
JavaScript实现点击出现子菜单效果
Feb 08 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
新的一年,新的期待:DC在2020年的四部动画电影
2020/01/01 欧美动漫
php中error与exception的区别及应用
2014/07/28 PHP
php实现的替换敏感字符串类实例
2014/09/22 PHP
CodeIgniter视图使用注意事项
2016/01/20 PHP
JavaScript库 开发规则
2009/01/31 Javascript
onkeydown事件解决按回车键直接提交数据的需求
2013/04/11 Javascript
jquery判断小数点两位和自动删除小数两位后的数字
2014/03/19 Javascript
Bootstrap每天必学之导航组件
2016/04/25 Javascript
js浏览器html5表单验证
2016/10/17 Javascript
Vue2组件tree实现无限级树形菜单
2017/03/29 Javascript
详解Vue 动态添加模板的几种方法
2017/04/25 Javascript
Angular排序实例详解
2017/06/28 Javascript
JavaScript实现随机数生成器(去重)
2017/10/13 Javascript
node 利用进程通信实现Cluster共享内存
2017/10/27 Javascript
Vue通过URL传参如何控制全局console.log的开关详解
2017/12/07 Javascript
vue脚手架中配置Sass的方法
2018/01/04 Javascript
详解一个基于套接字实现长连接的express
2019/03/28 Javascript
webpack 代码分离优化快速指北
2019/05/18 Javascript
[11:57]《一刀刀一天》第十七期:TI中国军团加油!
2014/05/26 DOTA
[00:29]2019完美世界全国高校联赛(秋季赛)总决赛海口落幕
2019/12/10 DOTA
Django URL传递参数的方法总结
2016/08/28 Python
对python中raw_input()和input()的用法详解
2018/04/22 Python
使用python画个小猪佩奇的示例代码
2018/06/06 Python
python实现opencv+scoket网络实时图传
2020/03/20 Python
CSS3美化表单控件全集
2016/06/29 HTML / CSS
CSS3中Animation属性的使用详解
2015/08/06 HTML / CSS
美国购买当代和现代家具网站:MODTEMPO
2018/07/20 全球购物
如何在存储过程中使用Loop
2016/01/05 面试题
预备党员党课思想汇报
2014/01/13 职场文书
2014报到证办理个人委托书
2014/10/08 职场文书
检讨书怎么写
2015/01/23 职场文书
歌咏比赛口号大全
2015/12/25 职场文书
七年级作文之英语老师
2019/10/28 职场文书
解析laravel使用workerman用户交互、服务器交互
2021/04/28 PHP
Python中的matplotlib绘制百分比堆叠柱状图,并为每一个类别设置不同的填充图案
2022/04/20 Python
详解Nginx的超时keeplive_timeout配置步骤
2022/05/25 Servers