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 相关文章推荐
jquery $.ajax入门应用一
Nov 19 Javascript
JS 动态获取节点代码innerHTML分析 [IE,FF]
Nov 30 Javascript
jQuery hover 延时器实现代码
Mar 12 Javascript
用Javascript评估用户输入密码的强度实现代码
Nov 30 Javascript
JavaScript实现网页上的浮动广告的简单方法
Jun 14 Javascript
JavaScript定义变量和变量优先级问题探讨
Oct 11 Javascript
整理关于Bootstrap模态弹出框的慕课笔记
Mar 29 Javascript
JS 验证密码 不能为空,必须含有数字、字母、特殊字符,长度在8-12位
Jun 21 Javascript
原生JS实现的自动轮播图功能详解
Dec 28 Javascript
vue项目中引入Sass实例方法
Aug 27 Javascript
Layui表格行工具事件与数据回填方法
Sep 13 Javascript
vue使用过滤器格式化日期
Jan 20 Vue.js
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
PHP连接sql server 2005环境配置及问题解决
2014/08/08 PHP
php根据日期显示所在星座的方法
2015/07/13 PHP
PHP redis实现超迷你全文检索
2017/03/04 PHP
PHP实现广度优先搜索算法(BFS,Broad First Search)详解
2017/09/16 PHP
jQuery 浮动广告实现代码
2008/12/25 Javascript
原生js拖拽(第一课 未兼容)拖拽思路
2013/03/29 Javascript
nullJavascript中创建对象的五种方法实例
2013/05/07 Javascript
5秒后跳转到另一个页面的js代码
2013/10/12 Javascript
JS(JQuery)操作Array的相关方法介绍
2014/02/11 Javascript
基于jQuery实现搜索关键字自动匹配功能
2020/03/26 Javascript
JS使用onerror捕获异常示例
2016/08/03 Javascript
BootStrap实现鼠标悬停下拉列表功能
2017/02/17 Javascript
详解wow.js中各种特效对应的类名
2017/09/13 Javascript
jQuery 利用ztree实现树形表格的实例代码
2017/09/27 jQuery
巧妙运用v-model实现父子组件传值的方法示例
2019/04/07 Javascript
node.js文件操作系统实例详解
2019/11/05 Javascript
JS通用方法触发点击事件代码实例
2020/02/17 Javascript
vue watch监控对象的简单方法示例
2021/01/07 Vue.js
[46:43]DOTA2上海特级锦标赛D组小组赛#1 EG VS COL第三局
2016/02/28 DOTA
Python中用post、get方式提交数据的方法示例
2017/09/22 Python
Python实现爬虫抓取与读写、追加到excel文件操作示例
2018/06/27 Python
python实现kmp算法的实例代码
2019/04/03 Python
python列表推导式入门学习解析
2019/12/02 Python
python实现密码验证合格程序的思路详解
2020/06/01 Python
Python wordcloud库安装方法总结
2020/12/31 Python
Django如何重置migration的几种情景
2021/02/24 Python
static函数与普通函数有什么区别
2015/12/25 面试题
RIP版本1跟版本2的区别
2013/12/30 面试题
技术副厂长岗位职责
2013/12/26 职场文书
电脑专业个人求职信范文
2014/02/04 职场文书
任命书格式
2014/06/05 职场文书
地理信息科学专业推荐信
2014/09/08 职场文书
2014年共青团工作总结
2014/12/10 职场文书
企业投资意向书
2015/05/09 职场文书
业务员年终工作总结2015
2015/05/28 职场文书
导游词之阳朔遇龙河
2019/12/16 职场文书