<style scoped lang="less">
.keyboard {
font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Helvetica Neue", STHeiti, "Microsoft Yahei", Tahoma, Simsun, sans-serif;
user-select: none;
font-size: 16px;
width: 100%;
} .input-box {
display: flex;
align-items: center;
justify-content: space-between;
line-height: 120px;
background-color: #fff;
border-radius: 8px;
font-size: 64px;
.label {
text-align: center;
width: 119px;
position: relative;
&::after {
content: "";
position: absolute;
/* display: inline-block; */
height: 64px;
top: 28px;
right: 0;
width: 2px;
background-color: rgb(221, 221, 221);
}
}
.content {
display: flex;
flex: 1;
.input { color: #313131;
}
.cursor {
background-color: #4788c5; width: 2px;
height: 64px;
margin-top: 28px;
margin-left: 2px;
}
.placeholder {
height: 120px;
padding-left: 38px;
}
.currency {}
}
}
</style>
<template>
<div class="keyboard">
<!-- 自定义输入框 -->
<div class="input-box" @touchstart.stop="focus">
<!-- 左侧标签 -->
<p class="label">¥ </p>
<!-- 右侧内容 -->
<div class="content"> <p class="placeholder" v-show="val.length === 0">
{{value}}
</p>
<!-- 光标 -->
<p class="cursor" :style="{visibility: cursor ? 'visible' : 'hidden'}"></p>
</div>
</div> </div> </template>
<script> export default {
name: 'KeyboardInput',
components: { },
created() {
/*闪烁光标*/
this.blinkCursor();
// document.addEventListener('touchstart', () => {
// this.blur();
// });
},
props: {
value: '',
inter: {
default: 5
},
decimal: {
default: 2
},
// label: {
// default: '消费金额'
// },
placeholder: {
default: '158898'
}
},
data() {
return {
cursor: false,
keyboard: false,
/*value 在组件中的值*/
val: '',
aIllegal: ['00', '01', '02', '03', '04', '05', '06', '07', '08', '09', '0..', '.'],
cursorDuration: 600,
bodyHeight: '',
bodyOverflow: ''
}
},
methods: {
/*focus*/
focus() {
/*显示键盘*/
this.showKeyboard();
/*显示光标*/
this.showCursor(); },
blinkCursor() {
clearInterval(this.intervalID);
this.intervalID = setInterval(() => {
this.cursor = !this.cursor;
}, this.cursorDuration);
},
unblinkCursor() {
clearInterval(this.intervalID);
},
/*blur*/
blur() {
/*隐藏光标*/
this.hideCursor();
/*停止光标闪烁*/
this.unblinkCursor();
/*隐藏键盘*/
this.hideKeyboard();
/*
附加 00, 如果用户输入了一个以 . 结尾的值就点完成了,
那么这个时候就在后面加上00
*/
this.toCompletion();
/*通知父组件, 老子值出来了*/
/*
校验用户输入的金额是不是为 0, 如果是的话, 直接重置
*/
this.checkValue();
this.notify(); },
showKeyboard() {
this.keyboard = true;
},
hideKeyboard() {
this.keyboard = false;
},
showCursor() {
this.cursor = true;
},
hideCursor() {
this.cursor = false;
},
checkValue() {
if (parseFloat(this.val) === 0) {
this.val = '';
}
},
/*判读是否需要加0*/
toCompletion() {
let list = this.value.split('.');
if (typeof list[1] === 'undefined') {
if (this.val !== '') {
this.val = this.val + '.';
this.completion(this.decimal);
}
} else {
if (list[1].length < this.decimal) {
this.completion(this.decimal - list[1].length);
}
}
},
completion(len) {
let v = '';
for (let i = 0; i < len; i++) {
v = v + '0';
}
this.val = this.val + v;
},
notify() {
this.$emit('input', this.val);
},
del() {
/*删除值并不会触发值的校验, 所以需要手动再触发一次*/
this.val = this.val.slice(0, -1);
this.notify();
},
/*输入*/
typing(value) {
/*如果是点击删除*/
if (value === '') {
this.del();
}
/*保存旧的值*/
let oldValue = this.val;
/*获取新的值*/
this.val = this.val + value;
/*检验新值, 如果没有通过检测, 恢复值*/
if (!this.passCheck(this.val)) {
this.val = oldValue;
return;
}
/*为了让外界同步输入, 需要发送事件*/
this.notify();
},
passCheck(val) {
/*验证规则*/
let aRules = [
this.illegalInput,
this.illegalValue,
this.accuracy
]
return aRules.every((item) => {
return item(val);
});
},
illegalInput(val) {
if (this.aIllegal.indexOf(val) > -1) {
return false;
}
return true;
},
/*非法值*/
illegalValue(val) {
if (parseFloat(val) != val) {
return false;
}
return true;
},
/*验证精度*/
accuracy(val) {
let v = val.split('.')
if (v[0].length > this.inter) {
return false;
}
if (v[1] && (v[1].length) > this.decimal) {
return false;
}
return true;
}
}
} </script>

移动端自定义输入框的vue组件 ----input的更多相关文章

  1. 移动端自定义键盘的vue组件 ----keyboard

    <style scoped lang="less"> .keyboard { /* height: 250px; */ width: 100%; position: f ...

  2. 移动端无限滚动 TScroll.vue组件

    // 先看使用TScroll.vue的几个demo 1.https://sorrowx.github.io/TScroll/#/ 2. https://sorrowx.github.io/TScrol ...

  3. Vue.js 桌面端自定义滚动条组件|vue美化滚动条VScroll

    基于vue.js开发的小巧PC端自定义滚动条组件VScroll. 前段时间有给大家分享一个vue桌面端弹框组件,今天再分享最近开发的一个vue pc端自定义滚动条组件. vscroll 一款基于vue ...

  4. webAPP如何实现移动端拍照上传(Vue组件示例)?

    摘要:使用HTML5编写移动Web应用,主要是为了尝试一下“一套代码多处运行”,一个webapp几乎可以不加修改的运行在PC/Android/iOS等上面运行.但是写到现在觉得虽然这种方式弊大于利,不 ...

  5. 在vue组件的stylus样式总 取消search类型的input按钮中默认样式

    在vue组件的stylus样式中 取消search类型的input按钮中默认样式 记录一个坑 环境 Vue组件 使用了Stylus的CSS风格. 问题 input输入框使用了 type="s ...

  6. vue组件、自定义指令、路由

    1.vue组件 组件(Component)是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码.组件系统让我们可以用独立可复用的小组件来构建大型应用,几乎任意类型的应用的 ...

  7. 基于React.js网页版弹窗|react pc端自定义对话框组件RLayer

    基于React.js实现PC桌面端自定义弹窗组件RLayer. 前几天有分享一个Vue网页版弹框组件,今天分享一个最新开发的React PC桌面端自定义对话框组件. RLayer 一款基于react. ...

  8. 使用VUE组件创建SpreadJS自定义单元格(二)

    在上篇中,我们介绍了如何通过设置runtimeCompiler为true,在Vue中实现了动态创建电子表格组件.想了解具体内容可看点击查看使用VUE组件创建SpreadJS自定义单元格(一). 但是在 ...

  9. Vue组件绑定自定义事件

    Vue组件使用v-on绑定自定义事件: 可以分为3步理解: 1.在组件模板中按照正常事件机制绑定事件: template: '<button v-on:click="increment ...

随机推荐

  1. 文本数据和mysql 里面的数据比较

    实现读取TXT文件中的内容然后存到内存,然后将内存中的数据和mysql 数据库里面某张表数据的字段做一个比较,如果比较内存中的数据在mysql 里存在则不做处理,如果不存在则将该数据插入mysql数据 ...

  2. Xpath-Extraction 关联

    //*[local-name()="qqCheckOnlineResult"] //开头 *代表的是任意的标签 local-name():寻找标签名

  3. QT5+Pylon

    VS+QT+Pylon:配置一下包含文件和libs,具体参考pylon说明文档. Windows下  Qtcreator+Pylon:建议把include和libs文件夹拷贝至工作目录,然后修改.pr ...

  4. python3 日志重复打印logger

    在python2中正常的日志,单只直接使用python3,发现日志重复了,其实是handlers多添加的原因, python2代码 ---------------------------------- ...

  5. php 获取不到post的值

    一般在ajax提交的时候出现这种情况 当我们在ajax参数设置   contentType: 'application/json; charset=utf-8', 用file_get_contents ...

  6. Hive中SQL查询转换成MapReduce作业的过程

  7. 随笔记录 grub引导故障修复 2019.8.7

    系统备份: [root@localhost ~]# mkdir /abc [root@localhost ~]# mount /dev/sdb1 /abc [root@localhost ~]# dd ...

  8. 【学术篇】SPOJ QTREE 树链剖分

    发现链剖这东西好久不写想一遍写对是有难度的.. 果然是熟能生巧吧.. WC的dalao们都回来了 然后就用WC的毒瘤题荼毒了我们一波, 本来想打个T1 44分暴力 然后好像是特判写挂了还是怎么的就只能 ...

  9. elast数据存放

    这几天一直在索引数据,突然发现服务器状态变红色了,去官网看了下 集群状态如果是红色的话表示有数据已经丢失了!这下头大了才索引了7G数据,后面还有10多个G, 我在liunx下看了下磁盘空间 发现运行e ...

  10. thinkphp rabc权限总结

    今天晚上把ThinkPHP的权限分配弄明白了,心里的包袱立刻放下了,感觉那个爽啊!稍微记录一下. 背景:CMS系统开发(17do). 项目分组:Admin(后台管理).Home(前台显示). Admi ...