温州市微信小程序怎么使用车牌号输入法
阅读 37003 · 发布日期 2020-08-24 17:26 · 温州优光网络科技有限公司|建站|APP小程序制作|做网站SEO推广优化
【摘要】
在做小程序时,做了一个关于车的项目,然后需要添加车辆信息、添加车牌号,使用车牌键盘输入,当时我把这个需求给砍了,然后在添加车辆信息时,老大看到数据库里我乱填的车牌号,又让我把他加上了^o^1、效果图2.相关代码使用组件形式实现键盘输入组件代码index.wxml{{item}}{{item}}{{item}}{{ite... 【温州小程序开发,温州微信公众号,平阳做网站,平阳网站建设公司,平阳小程序商城制作,昆阳万全做网站,鳌江水头小程序,萧江腾蛟微信公众号,山门顺溪南雁海西南麂凤卧麻步怀溪网络网店服务,政采云网店管理服务】...
在做小程序时,做了一个关于车的项目,然后需要添加车辆信息、添加车牌号,使用车牌键盘输入,当时我把这个需求给砍了,然后在添加车辆信息时,老大看到数据库里我乱填的车牌号,又让我把他加上了^o^1、效果图2.相关代码使用组件形式实现键盘输入组件代码index.wxml
{
item}
}
{
item}
}
{
item}
}
{
item}
}
{
item}
}
{
item}
}
{
item}
}
{
item}
}
position: fixed;
padding: 12rpx 12rpx 30rpx;
left: 0;
bottom: 0;
width: 100%;
/* height: 150px;
*/ font-size: 30rpx;
background: #fff;
box-sizing: border-box;
border-top: 1px solid rgb(211, 207, 207);
z-index: 200;
}
.wordList{
display: flex;
width: 100%;
justify-content: space-between;
align-items: center;
}
.wordItem{
margin: 5rpx;
width: 70rpx;
height: 70rpx;
line-height: 70rpx;
text-align: center;
border: 1px solid #eee;
border-radius: 10rpx;
}
.wordConfirm{
width: 130rpx;
color: #fff;
background: #473af0;
}
.wordClear{
width: 100rpx;
}
.clearImg{
width: 60rpx;
height: 60rpx;
vertical-align: middle;
}
index.jsComponent({
properties: {
type: {
type: Number, default: 1, }
, show: {
type: Boolean, default: false, }
}
, data: {
cityKeyword1: '
京沪浙苏粤鲁晋冀豫'
, cityKeyword2: '
川渝辽吉黑皖鄂湘赣'
, cityKeyword3: '
闽陕甘宁蒙津贵云'
, cityKeyword4: '
桂琼青新藏港澳台'
, keyNumber: '
1234567890'
, wordList1: '
QWERTYUIOP'
, wordList2: '
ASDFGHJKL'
, wordList3: '
ZXCVBNM'
, }
, methods: {
handleClick(e) {
let value = e.currentTarget.dataset.item;
let type = e.currentTarget.dataset.type;
switch(value) {
case '
confirm'
: this.triggerEvent('
confirm'
);
break;
case '
delete'
: this.triggerEvent('
delete'
);
break;
default: this.triggerEvent('
change'
, {
value, type }
);
}
}
}
}
)3.父组件引入我想实现点击输入后有上拉的效果,开始我想使用offset来实现的,但是下班后洗衣服想了下,不太好实现,我就想到了我以前做购物车时,有用到transform,原理差不多,我就把他用上了然后就是点击键盘外实现收起键盘,开始我想到的就是在父组件的最外层定义关闭事件,父级里面的盒子都使用catch方法阻止冒泡,但想下阻止冒泡好像又有点不合情理,就又把阻止冒泡给去掉了父组件index.wxml
{
carNo}
}
data: {
carNo: '
'
, translateSpace: 0, inputType: 1, // 车牌输入类型,1简称,2数字或者字母, showPlateInput: false, }
, /* 用于点击弹出键盘输入,space为键盘弹出后向上拉取的距离 */ handleClick(e) {
/* 150为键盘的高度 */ let space = -(e.currentTarget.offsetTop - 150);
/* regExp用于判断当前已输入的车牌号是否是中文,并让键盘显示中文还是英文输入 */ let regExp = /^[u4e00-u9fa5]+/;
let inputType = 1;
if(regExp.test(this.data.carNo)) {
inputType = 2;
}
this.setData({
translateSpace: space, showPlateInput: true, inputType }
) }
, /* 键盘输入操作 */ handlePlateChange(e) {
let value = e.detail.value;
let type = e.detail.type;
let carNo = this.data.carNo;
carNo += value;
if(type == 1) {
this.setData({
inputType: 2 }
) }
this.setData({
carNo }
) }
, /* 点击键盘上的确定 */ handlePlateConfirm() {
/* isCarPlate用于判断输入的车牌号是否符合规范 */ if (!this.isCarPlate(this.data.carNo)) {
wx.showToast({
title: '
请输入正确的车牌号'
, icon: '
none'
, duration: 2000 }
) return false;
}
this.setData({
translateSpace: 0, showPlateInput: false, inputType: 1 }
) }
, /* 用于键盘输入删除 */ handlePlateDelete(e) {
let carNo = this.data.carNo;
carNo = carNo.substring(0, carNo.length - 1);
if(carNo.length == 0) {
this.setData({
inputType: 1 }
) }
this.setData({
carNo, }
) }
, /* 判断车牌号 */ isCarPlate(value) {
return /^(([京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-Z](([0-9]{
5}
[DF])|([DF]([A-HJ-NP-Z0-9])[0-9]{
4}
)))|([京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-Z][A-HJ-NP-Z0-9]{
4}
[A-HJ-NP-Z0-9挂学警港澳使领]))$/.test(value);
}
}
)父组件index.css.container{
height: 100vh;
background: #fff;
}
.translateView{
background: #eee;
}
.list{
margin-bottom: 20rpx;
background: #fff;
}
.list:last-child{
margin: 0;
}
.item{
display: flex;
padding: 0 26rpx;
width: 100%;
height: 116rpx;
box-sizing: border-box;
align-items: center;
border-bottom: 1px solid #eee;
}
.item:last-child{
border: none;
}
.label{
margin-right: 10rpx;
width: 140rpx;
}
.contentBox{
display: flex;
width: calc(100% - 150rpx);
height: 90rpx;
align-items: center;
justify-content: space-between;
}
.promptText{
color: #c7c7c7;
}
.inputBox{
width: 100%;
height: 80rpx;
line-height: 80rpx;
}
正在努力学习中,若对你的学习有帮助,留下你的印记呗(点个赞咯^_^)推荐教程:
《微信小程序》以上就是微信小程序怎么使用车牌号输入法的详细内容,更多请关注php中文网其它相关文章!
微信
分享相关标签:
微信小程序 javascript本文转载于:
segmentfault,如有侵犯,请联系a@php.cn删除
上一篇:
用mpvue开发微信小程序基础知识
下一篇:
改进异步封装:
处理带返回值的异步调用 - 边城客栈相关文章相关视频微信小程序wx.request请求数据报错微信小程序加载失败是什么原因?微信小程序开发初次体验微信小程序常见的开发问题汇总微信小程序怎么使用车牌号输入法深入了解微信小程序(二)深入了解微信小程序(三)深入了解微信小程序(四) [温州做小程序]