移动端自定义输入框的vue组件 ----input
<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的更多相关文章
- 移动端自定义键盘的vue组件 ----keyboard
<style scoped lang="less"> .keyboard { /* height: 250px; */ width: 100%; position: f ...
- 移动端无限滚动 TScroll.vue组件
// 先看使用TScroll.vue的几个demo 1.https://sorrowx.github.io/TScroll/#/ 2. https://sorrowx.github.io/TScrol ...
- Vue.js 桌面端自定义滚动条组件|vue美化滚动条VScroll
基于vue.js开发的小巧PC端自定义滚动条组件VScroll. 前段时间有给大家分享一个vue桌面端弹框组件,今天再分享最近开发的一个vue pc端自定义滚动条组件. vscroll 一款基于vue ...
- webAPP如何实现移动端拍照上传(Vue组件示例)?
摘要:使用HTML5编写移动Web应用,主要是为了尝试一下“一套代码多处运行”,一个webapp几乎可以不加修改的运行在PC/Android/iOS等上面运行.但是写到现在觉得虽然这种方式弊大于利,不 ...
- 在vue组件的stylus样式总 取消search类型的input按钮中默认样式
在vue组件的stylus样式中 取消search类型的input按钮中默认样式 记录一个坑 环境 Vue组件 使用了Stylus的CSS风格. 问题 input输入框使用了 type="s ...
- vue组件、自定义指令、路由
1.vue组件 组件(Component)是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码.组件系统让我们可以用独立可复用的小组件来构建大型应用,几乎任意类型的应用的 ...
- 基于React.js网页版弹窗|react pc端自定义对话框组件RLayer
基于React.js实现PC桌面端自定义弹窗组件RLayer. 前几天有分享一个Vue网页版弹框组件,今天分享一个最新开发的React PC桌面端自定义对话框组件. RLayer 一款基于react. ...
- 使用VUE组件创建SpreadJS自定义单元格(二)
在上篇中,我们介绍了如何通过设置runtimeCompiler为true,在Vue中实现了动态创建电子表格组件.想了解具体内容可看点击查看使用VUE组件创建SpreadJS自定义单元格(一). 但是在 ...
- Vue组件绑定自定义事件
Vue组件使用v-on绑定自定义事件: 可以分为3步理解: 1.在组件模板中按照正常事件机制绑定事件: template: '<button v-on:click="increment ...
随机推荐
- 学习k8s的经验
最近在学k8s,总结一下安装k8s的坑. 1.晚上关于k8s的学习资料很多,多不如精,这个博客很好,https://blog.csdn.net/sinat_35930259/article/categ ...
- luogu3384 /// 树链剖分+线段树模板
题目大意: https://www.luogu.org/problemnew/show/P3384 树链剖分的讲解 两个dfs() 修改 查询 很详细很好理解 https://www.cnblogs. ...
- 【POJ】3268 Silver Cow Party
题目链接:http://poj.org/problem?id=3268 题意 :有N头奶牛,M条单向路.X奶牛开party,其他奶牛要去它那里.每头奶牛去完X那里还要返回.去回都是走的最短路.现在问这 ...
- Spring MVC @RequestParam(5)
案例来说明 1 @RequestMapping("user/add") 2 public String add(@RequestParam("name") St ...
- 正版STlink的使用注意
https://blog.csdn.net/xinghuanmeiying/article/details/78026561
- 9.ActiveMQ理论
一.首先说下什么是消息队列? 1.消息队列是在消息的传输过程中保存消息的容器. 二.为什么要用到消息队列? 主要原因是由于在高并发环境下,由于来不及同步处理,请求往往会发生堵塞,比如说,大量的inse ...
- java oop遍历List和Map的几种方法
一.list的遍历 import java.util.*; public class ListTest { public static void main(String[] args) { List& ...
- Ansible配置及使用
使用公私钥实现ssh无密码登录 生成公钥和私钥 ssh-keygen -t rsa 公钥相当于锁id_rsa.pub,私钥相当于钥匙id_rsa 借用ssh-copy-id工具实现无密码登录 ssh- ...
- eclipse导出说明文档
选中项目--右键--Export--Java--Javadoc—Finish 1.为程序添加文档注释 2.选中项目--右键Export--Java--Javadoc--next, 3.next--在V ...
- sql (9) COUNT
COUNT() 函数返回匹配指定条件的行数.语法SQL COUNT(column_name) 语法COUNT(column_name) 函数返回指定列的值的数目(NULL 不计入):新建表 Stude ...