Maison > interface Web > js tutoriel > le corps du texte

Utiliser jquery pour implémenter un clavier de paiement similaire à Alipay sur le terminal mobile (code)

不言
Libérer: 2018-08-15 10:18:01
original
2111 Les gens l'ont consulté

Le contenu de cet article concerne l'utilisation de jquery pour implémenter un clavier de paiement similaire à Alipay sur le terminal mobile. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. .

Lorsque je travaillais récemment sur un projet, je suis tombé sur une exigence, qui consiste à cliquer sur le bouton de paiement sur la page de paiement mobile pour faire apparaître un clavier de paiement, similaire à Alipay. Étant donné que le projet n'est qu'un site Web mobile, pas une application, cette fonction doit être implémentée par le front-end. Sans plus attendre, regardons la photo pour voir l’effet.

Nima, n'est-ce pas le clavier de paiement sur l'application Alipay ? Oui, notre interface utilisateur est basée sur le clavier fabriqué par Alipay. Vous vous demandez peut-être pourquoi ne pas appeler directement l'interface de paiement fournie par Alipay. Eh bien, parce que le projet l’exige, je n’expliquerai pas grand-chose ici.

Jetons d'abord un coup d'œil aux rendus après la mise en œuvre

  🎜>

La partie principale de JS

<!-- 支付键盘 -->
    <divclass="pay-container">
        <divclass="pay-title">
            <spanclass="pay-title-remove">×</span>
            输入支付密码
        </div>
        <divclass="pay-body">
            <divclass="input-container">
                <inputclass="input-item"type="password"readonly>
                <inputclass="input-item"type="password"readonly>
                <inputclass="input-item"type="password"readonly>
                <inputclass="input-item"type="password"readonly>
                <inputclass="input-item"type="password"readonly>
                <inputclass="input-item"type="password"readonly>
            </div>
            <divclass="forgetPwd-container">
                <aclass="forgetPwd"href="">忘记密码?</a>
            </div>
            <divclass="key-container">
                <divclass="key-item">1</div>
                <divclass="key-item">2</div>
                <divclass="key-item">3</div>
                <divclass="key-item">4</div>
                <divclass="key-item">5</div>
                <divclass="key-item">6</div>
                <divclass="key-item">7</div>
                <divclass="key-item">8</div>
                <divclass="key-item">9</div>
                <divclass="key-item empty"></div>
                <divclass="key-item">0</div>
                <divclass="key-item remove"></div>
            </div>
        </div>
    </div>
Copier après la connexion
Là il n'y a qu'une quantité limitée de code et ce n'est pas compliqué. C’est peut-être écrit de manière grossière, mais l’effet est visible.

Recommandations associées :
.pay-container{ width:7.5rem; height:8rem; background-color:#fbf9fb; position:fixed;z-index:999; overflow:hidden;display:none; }
/* .pay-container-show{transform: translate3d(0, -8.9rem, 0);transition: 0.5s ease;transform: translate3d(0, 0, 0); transition: 0.5s ease;} */
.pay-title{ height:0.96rem; line-height:0.96rem; border-bottom:1pxsolid#b3afaf; text-align:center; color:#070707;
position:relative; font-size:0.36rem;}
.pay-title.pay-title-remove{ width:0.24rem; height:0.24rem; position:absolute; top:0.35rem; left:0.33rem; line-height:0.28rem;
font-size:0.45rem;}
.pay-body{ padding-top:0.56rem;position:relative; height:7rem; box-sizing:border-box;}
.pay-body.input-container{ width:6.74rem; height:0.93rem; border:1pxsolid#ebe8eb; overflow:hidden; border-radius:5px;
background-color:#fff; margin:0auto; display:flex;flex-direction:row;align-items:center; 
flex-wrap:wrap; justify-content:center;align-content:center;}
.pay-body.input-container.input-item{ width:1.1rem; height:0.92rem; display:inline-block; margin:0; border-right:1pxsolid#ebe8eb;
text-align:center; line-height:0.92rem; border-radius:0; }
.pay-body.input-container.input-item:nth-last-child(1){ border-right:0;}
.pay-body.forgetPwd-container{width:6.74rem;margin:0.22remauto0; text-align:right;}
.pay-body.forgetPwd-container.forgetPwd{ color:#52bfff; font-size:0.24rem; }
.pay-body.key-container{ width:100%; height:4.56rem; position:absolute; bottom:0; display:flex;flex-direction:row;align-items:center; 
    flex-wrap:wrap; justify-content:center;align-content:center; }
.pay-body.key-container.key-item{ width:2.47rem; height:1.12rem; line-height:1.12rem; text-align:center; border-right:2pxsolid#f3f3f3;
    border-top:2pxsolid#f3f3f3; font-size:0.66rem; color:#1e1d1f;background-color:#fff;}
.pay-body.key-container.key-item:nth-child(3),
.pay-body.key-container.key-item:nth-child(6),
.pay-body.key-container.key-item:nth-child(9),
.pay-body.key-container.key-item:nth-child(12){ border-right:0;}
.pay-body.key-container.key-item.remove,.pay-body.key-container.key-item.empty{ font-size:0.24rem;background-color:#e6e9f1;}
.pay-body.key-container.key-item.remove{ background:url(&#39;../images/pay-remove.png&#39;) centerno-repeat#e6e9f1; background-size:.52rem.32rem; }
.pay-body.key-container.selected{ background-color:#e4e8f4;}
Copier après la connexion

Page de paiement mobile JQuery Mobile Alipay
var arr = [];
        var num =0;

        //响应键盘事件
        $(&#39;.key-item&#39;).on(&#39;touchstart&#39;, function () {
            $(this).addClass(&#39;selected&#39;)
        })
        $(&#39;.key-item&#39;).on(&#39;touchend&#39;, function () {
            $(this).removeClass(&#39;selected&#39;)
        })
        $(&#39;.key-item&#39;).on(&#39;click&#39;, function () {
            var value =$(this).text();
            var inputItem =$(&#39;.layui-m-layercont .input-item&#39;);
            if (!$(this).hasClass(&#39;remove&#39;)) {
                if (num <6) {
                    $(inputItem[num]).val(value);
                    if (num ==5) {
                        var arr = [];
                        for (var i =0; i < inputItem.length; i++) {
                            arr.push(inputItem[i].value)
                        }
                        arr =parseInt(arr.join(&#39;&#39;));
                        if (arr !==123456) {
                            layer.open({
                                content:&#39;支付密码错误请重新输入!&#39;,
                                skin:&#39;msg&#39;,
                                time:2//2秒后自动关闭
                            });
                        } else {
                            layer.open({
                                content:&#39;输入正确!&#39;,
                                skin:&#39;msg&#39;,
                                time:2//2秒后自动关闭
                            });
                        }
                        num++;
                        returnfalse;
                    }
                    num++;
                }
            } else {
                if (num >0) {
                    num--;
                    $(inputItem[num]).val(&#39;&#39;);
                }
            }
        })
Copier après la connexion

Qui peut me parler du processus pour accéder à Alipay pour payer depuis le client mobile puis revenir ?

client Android Alipay php écriture côté serveur

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal