博客
关于我
一个车牌输入组件(vue)
阅读量:386 次
发布时间:2019-03-05

本文共 4128 字,大约阅读时间需要 13 分钟。

一个简单的车牌输入组件(vue)

效果图:
在这里插入图片描述
vue代码:

event事件:

export let life = {     created () {       // this.currentPlate = this.plateNumber    // console.log(this.plateNumber)    // this.EnterPlateNumber.input.firstWord = this.plateNumber.slice(0,1)    // this.EnterPlateNumber.input.secondWord = this.plateNumber.slice(1,2)    // this.EnterPlateNumber.input.lastWords = this.plateNumber.slice(2,9)  }}export let event = {     clickInput (type) {       this.methods('clickInput',type)  },  clickKeyboard (val) {       if (this.plateInput.input.type === 'p2' && parseInt(val) >= 0 && parseInt(val) <= 9) return    this.methods('clickKeyboard', val)    this.methods('setPlateNumber')    this.methods('setDirectIssuedPlateNumber')  },  //删除车牌  clickDelete () {       this.methods('clickDelete')    this.methods('setPlateNumber')    this.methods('setDirectIssuedPlateNumber')  },  hiddenKeybord(){       this.methods('hiddenKeybord')  },  enterWord(){       this.methods('enterWord')  }}export let watch = {   }

methods方法:

export default class {     clickInput(type){       this.plateInput.input.type = type    this.plateInput.input.dialogVisible = true  }  hiddenKeybord(){       this.plateInput.input.dialogVisible = false  }  enterWord(){       this.plateInput.input.dialogVisible = false  }  clickKeyboard (val) {       this.plateInput.input.value[this.plateInput.input.type] = val    let type = this.plateInput.input.type.split('p')[1]    if (type !== '8') {         this.plateInput.input.type = 'p' + (parseInt(type) + 1)    }  }  clickDelete () {       this.plateInput.input.value[this.plateInput.input.type] = undefined    let nu = this.plateInput.input.type.split('p')[1]-1    if(nu>=0){         this.plateInput.input.value['p'+nu] = undefined    }    let type = this.plateInput.input.type.split('p')[1]    if (type !== '1') {         this.plateInput.input.type = 'p' + (parseInt(type) - 1)    }  }  setPlateNumber () {       if (this.plateInput.input.plateNumber) {         this.plateNumber1 = this.plateInput.input.plateNumber    }else{         this.plateNumber1 = undefined    }  }  setDirectIssuedPlateNumber () {       if (this.plateInput.input.plateNumber) {         this.plateNumber1 = this.plateInput.input.plateNumber    }else{         this.plateNumber1 = undefined    }  }}

model数据:

export let props = ['name','plateNumber','noRightPart']export let model = {     currentPlate:undefined,  plateInput:{       input:{         value:{           p1:'桂',        p2:'B',        p3:2,        p4:2,        p5:2,        p6:2,        p7:2,        p8:0      },      type:'p1',      dialogVisible:false    }  },  Keyboard: {       province: ['京', '津', '冀', '晋', '蒙', '辽', '吉', '黑', '沪', '苏', '浙', '皖', '闽', '赣', '鲁', '豫', '鄂', '湘', '粤', '桂', '琼', '渝', '川', '贵', '云', '藏', '陕', '甘', '青','宁','新','台','港','澳','使','领','警','学'],    number: ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C','D', 'E', 'F', 'G','H', 'J', 'K', 'L', 'M', 'N', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '学', '港', '澳']  },}export let computed = {     plateNumber1 : {       get () {         return this.plateNumber||''    },    set (val) {         this.$emit('update:plateNumber', val)    }  }}

因为这里用了独家的框架,所以根据需要把相应的生命周期函数放到正常的vue项目的位置,把event就写成正常的函数,methods就是i正常的methods里面的方法,model就是data里return的数据

转载地址:http://ksgwz.baihongyu.com/

你可能感兴趣的文章
NET3.0+中使软件发出声音[整理篇]<转>
查看>>
net::err_aborted 错误码 404
查看>>
NetApp凭借领先的混合云数据与服务把握数字化转型机遇
查看>>
NetAssist网络调试工具使用指南 (附NetAssist工具包)
查看>>
Netbeans 8.1启动参数配置
查看>>
NetBeans IDE8.0需要JDK1.7及以上版本
查看>>
NetBeans之JSP开发环境的搭建...
查看>>
NetBeans之改变难看的JSP脚本标签的背景色...
查看>>
netbeans生成的maven工程没有web.xml文件 如何新建
查看>>
netcat的端口转发功能的实现
查看>>
NetCore 上传,断点续传,可支持流上传
查看>>
Netcraft报告: let's encrypt和Comodo发布成千上万的网络钓鱼证书
查看>>
Netem功能
查看>>
netfilter应用场景
查看>>
Netflix:当你按下“播放”的时候发生了什么?
查看>>
Netflix推荐系统:从评分预测到消费者法则
查看>>
netframework 4.0内置处理JSON对象
查看>>
Netgear WN604 downloadFile.php 信息泄露漏洞复现(CVE-2024-6646)
查看>>
Netgear wndr3700v2 路由器刷OpenWrt打造全能服务器(十一)备份
查看>>
netlink2.6.32内核实现源码
查看>>