一、el-table 行加样式类名(row-class-name)生效了,但是效果检测不到

1、问题

2、解决

关闭浏览器,重启程序

二、解决VUE项目在微信浏览器中使用支付宝支付提示复制链接到浏览器打开

1、问题:在微信浏览器中访问支付宝支付接口

  1. 分析及解决:访问支付宝接口会返回一个form 表单,一般我们拿到数据会先在本页面创造一个div标签,并将得到的form表单增加到div标签中,再将该表单进行submit提交操作,进而跳转支付宝支付环境。

代码如下:


let res_newBody = res.data.alipay.body;
const from = res_newBody;
var div = document.createElement('div');
div.id = 'alipay'
div.innerHTML = from;
document.body.appendChild(div);
// document.querySelector('#alipay').children[0].acceptCharset = 'GBK';
document.querySelector('#alipay').children[0].submit();
//执行submit表单提交,让页面重定向,跳转到支付宝页面

现在我们需要在拿到form表单后将其加密转换,以get方法跳转另一个页面,再在另一个新建页面里面提交!(我在本项目里命名为zfb.html,需要注意在文件需要和index.html 同级)

代码如下:

(1)、访问支付宝链接,加密form表单,跳中转页面

        this.$API.reqUserAlipy(data).then(res => {
         // 访问支付宝链接
          if (res.data) {
            if (res.data.alipay && res.data.alipay.body) {
            // 将拿到的form 表单先加密
              that.alipay_html = that.Base64().encode(res.data.alipay.body)

              if (that.alipay_html != '') {
                // 拿到后跳转页面(zfb.html)
                window.location.href = 'http://' + that.useUrl + '/zfb.html?alidata=' + this.alipay_html
              }
            }
          }
        });

(2)、加密方法。位置随意,为了方便可以和上面访问支付链接在同一vue文件!

    // 加密结果
    Base64() {
      return {
        // private property  
        _keyStr: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",

        // public method for encoding  
        encode: function (input) {
          var output = "";
          var chr1, chr2, chr3, enc1, enc2, enc3, enc4;
          var i = 0;
          input = this._utf8_encode(input);
          while (i < input.length) {
            chr1 = input.charCodeAt(i++);
            chr2 = input.charCodeAt(i++);
            chr3 = input.charCodeAt(i++);
            enc1 = chr1 >> 2;
            enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
            enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
            enc4 = chr3 & 63;
            if (isNaN(chr2)) {
              enc3 = enc4 = 64;
            } else if (isNaN(chr3)) {
              enc4 = 64;
            }
            output = output +
              this._keyStr.charAt(enc1) + this._keyStr.charAt(enc2) +
              this._keyStr.charAt(enc3) + this._keyStr.charAt(enc4);
          }
          return output;
        },
        // private method for UTF-8 encoding  
        _utf8_encode: function (string) {
          string = string.replace(/\r\n/g, "\n");
          var utftext = "";
          for (var n = 0; n < string.length; n++) {
            var c = string.charCodeAt(n);
            if (c < 128) {
              utftext += String.fromCharCode(c);
            } else if ((c > 127) && (c < 2048)) {
              utftext += String.fromCharCode((c >> 6) | 192);
              utftext += String.fromCharCode((c & 63) | 128);
            } else {
              utftext += String.fromCharCode((c >> 12) | 224);
              utftext += String.fromCharCode(((c >> 6) & 63) | 128);
              utftext += String.fromCharCode((c & 63) | 128);
            }

          }
          return utftext;
        },
      }
    },

(3)、zgf.html 页面。解密(转码),提交form表单

<!DOCTYPE html>
<html lang="en">

<head>
    <meta content="yes" name="apple-mobile-web-app-capable" />
    <meta name="viewport"
        content="width=device-width, height=device-height, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
    <meta charset="utf-8" />
    <meta name="referrer" content="no-referrer" />
    <meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate" />
    <meta http-equiv="Pragma" content="no-cache" />
    <meta http-equiv="Expires" content="0" />
    <title>支付宝</title>
    <style>
        *,
        :before,
        :after {
            -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        }

        body,
        div,
        dl,
        dt,
        dd,
        ul,
        ol,
        li,
        h1,
        h2,
        h3,
        h4,
        h5,
        h6,
        form,
        fieldset,
        legend,
        input,
        textarea,
        p,
        blockquote,
        th,
        td {
            margin: 0;
            padding: 0;
        }

        table {
            border-collapse: collapse;
            border-spacing: 0;
        }

        fieldset,
        img {
            border: 0;
        }

        li {
            list-style: none;
        }

        caption,
        th {
            text-align: left;
        }

        q:before,
        q:after {
            content: '';
        }

        input:password {
            ime-mode: disabled;
        }

        :focus {
            outline: 0;
        }

        html,
        body {
            -webkit-touch-callout: none;
            touch-callout: none;
            -webkit-user-select: none;
            user-select: none;
            -webkit-tap-highlight-color: transparent;
            tap-highlight-color: transparent;
            height: 100%;
            margin: 0;
            padding: 0;
            text-align: center;
            font-size: 15px;
            font-weight: 300;
            font-family: 'Helvetica Neue', Helvetica, Arial, 'Lucida Grande', sans-serif;
        }

        a {
            text-decoration: none;
        }

        body {
            background: #f4f4f8;
        }

        .weixin-tip {
            display: none;
            -webkit-box-sizing: border-box;
            box-sizing: border-box;
            position: absolute;
            top: 15px;
            right: 20px;
            width: 265px;
            padding: 55px 0 0;
            text-align: left;
            background: url() no-repeat right top;
            background-size: 45px 68px;
        }

        .weixin-tip-img {
            display: none;
            padding: 110px 0 0;
        }

        .weixin-tip-img::after {
            display: block;
            margin: 15px auto;
            content: ' ';
            background-size: cover;
        }

        .weixin-tip-img.iphone::after {
            width: 150px;
            height: 150px;
            background-image: url();
        }

        .weixin-tip-img.android::after {
            width: 173px;
            height: 240px;
            background-image: url();
        }

        .box {
            width: 250px;
            height: 100px;
            background: #fff;
            z-index: 2;
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%, -50%);
            border-radius: 24px;
            display: none;
        }

        .content {
            width: 100%;
            height: 100%;
            display: flex;
            justify-content: center;
            align-items: center;
            position: relative;
            flex-direction: column;
        }

        .btnmenu {
            width: 100%;
            display: flex;
            flex-direction: row;
            justify-content: center;
            position: relative;
            bottom: -24px;
        }

        .success {
            height: 30px;
            width: 50%;
            display: flex;
            justify-content: center;
            border-bottom-left-radius: 24px;
            border: 1px solid #F6F6F8;
            border-right: none;
            align-items: center;
        }

        .fail {
            height: 30px;
            width: 50%;
            display: flex;
            justify-content: center;
            border-bottom-right-radius: 24px;
            border: 1px solid #F6F6F8;
            align-items: center;
        }

        .men {
            background: #000000;
            opacity: 0.5;
            position: fixed;
            top: 0;
            height: 100%;
            width: 100%;
        }
    </style>
    <script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
</head>

<body>
    <div>
        <div class="J-weixin-tip weixin-tip" id="wxtip">
            <div class="weixin-tip-content">
                请在菜单中选择在浏览器中打开,
                <br />以完成支付
            </div>
        </div>
        <div class="J-weixin-tip-img weixin-tip-img" id="wxpic"></div>
        <div v-if="!isWeixin">
            <div class="payment-form" v-html="paymentForm"></div>
        </div>
    </div>
    <div class='men'></div>
    <div class="box">
        <div class="content">退出支付
            <div class="btnmenu">
                <!-- <div class="success">退出</div> -->
                <div class="fail">确定</div>
            </div>
        </div>

    </div>
</body>

</html>


<script>
    var paymentForm = ''
    $(function () {
        var base = new Base64();
        paymentForm =base.decode(GetQueryValue());
        console.log(paymentForm)
        var ua = navigator.userAgent.toLowerCase()
        if (ua.indexOf('micromessenger') != -1) {
            $('#wxtip').css('display', 'block')
            $('#wxpic').css('display', 'block')

            if (
                ua.indexOf('iphone') != -1 ||
                ua.indexOf('ipad') != -1 ||
                ua.indexOf('ipod') != -1
            ) {
                $('#wxpic').attr('class', 'J-weixin-tip-img weixin-tip-img iphone')
            } else {

                $('#wxpic').attr('class', 'J-weixin-tip-img weixin-tip-img android')
            }
        } else {
            SubmitPay()
        }
        setTimeout(function () {
            $('.box').css('display', 'block')
        }, 10000)

    })
    $('.success').on('click', function () {
        window.location.href = window.location.protocol +
            '//' +
            window.location.host +
            '/#/Profile';

    })
    $('.fail').on('click', function () {
        window.location.href = window.location.protocol +
            '//' +
            window.location.host +
            '/#/Profile';

    })
//进行支付宝表单提交  网上有很多熬
    function SubmitPay() {
        setTimeout(() => {
            const div = document.createElement('div')
            div.innerHTML = paymentForm
            document.body.appendChild(div)
            console.log(div);
            document.forms[0].submit()
        }, 50)
    }
//截取第一个等号后面的值  我自己写的因为我只携带了一个参数  所以自己写的截取 写的有点辣鸡,想要多个参数的可以自己改一下。
    function GetQueryValue() {
        var loc = decodeURI(window.location.href)
        var index = loc.indexOf('=')
        var newUrl = loc.substr(index + 1)
        return newUrl
    }
    //转码
    function Base64() {

        // private property  
        _keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
        // public method for decoding  
        this.decode = function (input) {
            var output = "";
            var chr1, chr2, chr3;
            var enc1, enc2, enc3, enc4;
            var i = 0;
            input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");
            while (i < input.length) {
                enc1 = _keyStr.indexOf(input.charAt(i++));
                enc2 = _keyStr.indexOf(input.charAt(i++));
                enc3 = _keyStr.indexOf(input.charAt(i++));
                enc4 = _keyStr.indexOf(input.charAt(i++));
                chr1 = (enc1 << 2) | (enc2 >> 4);
                chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
                chr3 = ((enc3 & 3) << 6) | enc4;
                output = output + String.fromCharCode(chr1);
                if (enc3 != 64) {
                    output = output + String.fromCharCode(chr2);
                }
                if (enc4 != 64) {
                    output = output + String.fromCharCode(chr3);
                }
            }
            output = _utf8_decode(output);
            return output;
        }
        // private method for UTF-8 decoding  
        _utf8_decode = function (utftext) {
            var string = "";
            var i = 0;
            var c = c1 = c2 = 0;
            while (i < utftext.length) {
                c = utftext.charCodeAt(i);
                if (c < 128) {
                    string += String.fromCharCode(c);
                    i++;
                } else if ((c > 191) && (c < 224)) {
                    c2 = utftext.charCodeAt(i + 1);
                    string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));
                    i += 2;
                } else {
                    c2 = utftext.charCodeAt(i + 1);
                    c3 = utftext.charCodeAt(i + 2);
                    string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
                    i += 3;
                }
            }
            return string;
        }
    }
</script>
  1. 展示

iphone

Android

Logo

前往低代码交流专区

更多推荐