You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
mianxueyoupin/components/wanl-pay-password/wanl-pay-password.vue

288 lines
17 KiB

4 months ago
<template>
<view class="best-modal digital-keyboard-modal" :class="{'best-modal-active':_show}">
<view class="best-modal-layer" @tap="cancel"></view>
<view class="best-modal-content">
<view class="dk-title">输入密码</view>
<view class="dk-subtitle">请输入支付密码</view>
<view class="pwd-box clearfix" @tap="getKeyboard">
<view class="pwd-text" v-for="(item,index) in _digits" :key="index" :class="{active:(activeInput==index)}">{{payPassWord[index]}}</view>
</view>
<view class="pwd-forget">
<text v-if="_forget" @tap="forgetPwd">没有密码?</text> <text v-if="_forget" @tap="forgetPwd">忘记密码</text>
</view>
<view class="digital-keyboard">
<view class="form_edit clearfix">
<view class="num" v-for="item in digitalList" :key="item" :class="{'no-num':(item === '' || item === '-1')}"
@tap="getKeyNumber(item)">{{item}}</view>
</view>
</view>
</view>
</view>
</template>
<script>
export default {
name: 'WanlPayPassword',
props: {
show: {
type: Boolean,
default: false
},
value: {
type: String,
default: ''
},
digits: {
type: [Number, String],
default: 6
},
forget: {
type: Boolean,
default: true
},
},
data() {
return {
activeInput: 0,
digitalList: ['1', '2', '3', '4', '5', '6', '7', '8', '9', '', '0', '-1'],
paymentPwd: ''
};
},
computed: {
payPassWord() {
var payPassWord = this.paymentPwd.split('') || [];
payPassWord.fill('•');
return payPassWord;
},
_show() {
this.initData();
return String(this.show) === 'false' ? false : true;
},
_forget() {
return String(this.forget) === 'false' ? false : true;
},
_digits() {
let digits = [];
digits.length = this.digits;
return digits;
}
},
methods: {
initData: function() {
this.paymentPwd = this.value;
this.activeInput = this.value.length;
},
forgetPwd: function() {
console.log('跳转到忘记密码')
},
cancel: function() {
this.$emit('cancel');
},
getKeyNumber: function(val) {
if (val === '' || (val != -1 && this.activeInput == this.digits)) { //空或者已经达到最大值
return false;
} else if (val != -1) { //数字输入
this.activeInput++
this.paymentPwd += val;
if (this.activeInput == this.digits) { //验证密码正确性
return this.$emit('submit', this.paymentPwd);
}
} else { //删除
if (this.activeInput != 0) {
this.activeInput--;
this.paymentPwd = this.paymentPwd.substr(0, this.activeInput)
}
}
},
getKeyboard: function(e) {
var index = e.target.dataset.index;
if (index === undefined) return false;
var _length = this.paymentPwd.length
this.activeInput = index <= _length ? index : _length;
}
}
}
</script>
<style>
.clearfix::before,
.clearfix::after {
content: "";
display: table;
clear: both;
}
.clearfix {
zoom: 1;
}
.best-modal {
position: fixed;
left: 0;
right: 0;
top: 0;
bottom: 0;
display: none;
z-index: 99;
}
.best-modal.best-modal-active {
display: block;
}
.best-modal-layer {
background-color: rgba(0, 0, 0, 0.2);
position: fixed;
left: 0;
right: 0;
top: 0;
bottom: 0;
z-index: 1025;
}
.best-modal-content {
position: relative;
z-index: 9999;
}
.digital-keyboard-modal view {
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
.digital-keyboard-modal .best-modal-content {
position: absolute;
left: 0;
right: 0;
bottom: 0;
padding-bottom: env(safe-area-inset-bottom);
border-radius: 20px 20px 0px 0px;
background: #fff url(
}
.digital-keyboard-modal .dk-title {
font-size: 36rpx;
font-weight: 800;
color: #fff;
line-height: 90rpx;
text-align: center;
}
.digital-keyboard-modal .dk-subtitle {
font-size: 24rpx;
color: rgba(152, 152, 148, 1);
line-height: 73rpx;
text-align: center;
}
.digital-keyboard-modal .pwd-forget {
font-size: 24rpx;
color: #26C6B3;
padding: 20rpx 0 30rpx;
text-align: center;
line-height: 33rpx;
}
.digital-keyboard-modal .pwd-forget text{
margin: 0 10rpx;
}
/* 键盘 */
.digital-keyboard-modal .form_edit {
position: relative;
}
.digital-keyboard-modal .num {
-webkit-transition: all .2s linear;
-o-transition: all .2s linear;
transition: all .2s linear;
float: left;
background-color: #fff;
width: 33.33333333%;
cursor: pointer;
border: 1rpx solid #eee;
height: 118rpx;
text-align: center;
color: #333;
line-height: 118rpx;
font-size: 52rpx;
/* font-weight: bold; */
}
.digital-keyboard-modal .num:nth-of-type(3n) {
border-bottom: 0;
border-right: 0;
}
.digital-keyboard-modal .num:nth-of-type(3n+1) {
border-bottom: 0;
border-left: 0;
}
.digital-keyboard-modal .num:nth-of-type(3n+2) {
border-bottom: 0;
border-left: 0;
border-right: 0;
}
.digital-keyboard-modal .num.no-num {
font-size: 0;
}
.digital-keyboard-modal .num:last-child {
background: #f2f2f2 url() center center / auto 50rpx no-repeat;
}
.digital-keyboard-modal .pwd-box {
padding-left: 10rpx;
position: relative;
text-align: center;
}
.digital-keyboard-modal .pwd-text {
position: relative;
line-height: 92rpx;
vertical-align: middle;
text-align: center;
font-size: 50rpx;
font-weight: bold;
width: 92rpx;
height: 92rpx;
margin-right: 10rpx;
display: inline-block;
border: solid 1px #ccc;
}
.digital-keyboard-modal .pwd-text.active:after {
-webkit-animation: twinkle 1s infinite;
animation: twinkle 1s infinite;
height: 70%;
width: 4rpx;
content: '';
position: absolute;
top: 15%;
left: 50%;
margin-left: -2rpx;
background-color: #4fa5e1;
}
@-webkit-keyframes twinkle {
from {
background-color: #4fa5e1;
}
to {
background-color: transparent;
}
}
@keyframes twinkle {
from {
background-color: #4fa5e1;
}
to {
background-color: transparent;
}
}
</style>