每天bug---1、el-table 行加样式类名(row-class-name)生效了,但是效果检测不到;2、解决VUE项目在微信浏览器中使用支付宝支付提示复制链接到浏览器打开

这篇具有很好参考价值的文章主要介绍了每天bug---1、el-table 行加样式类名(row-class-name)生效了,但是效果检测不到;2、解决VUE项目在微信浏览器中使用支付宝支付提示复制链接到浏览器打开。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

1、问题

每天bug---1、el-table 行加样式类名(row-class-name)生效了,但是效果检测不到;2、解决VUE项目在微信浏览器中使用支付宝支付提示复制链接到浏览器打开,bug,前端,vue,elementui,Powered by 金山文档

2、解决

关闭浏览器,重启程序

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

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

每天bug---1、el-table 行加样式类名(row-class-name)生效了,但是效果检测不到;2、解决VUE项目在微信浏览器中使用支付宝支付提示复制链接到浏览器打开,bug,前端,vue,elementui,Powered by 金山文档
每天bug---1、el-table 行加样式类名(row-class-name)生效了,但是效果检测不到;2、解决VUE项目在微信浏览器中使用支付宝支付提示复制链接到浏览器打开,bug,前端,vue,elementui,Powered by 金山文档
  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 同级)

每天bug---1、el-table 行加样式类名(row-class-name)生效了,但是效果检测不到;2、解决VUE项目在微信浏览器中使用支付宝支付提示复制链接到浏览器打开,bug,前端,vue,elementui,Powered by 金山文档

代码如下:

(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

每天bug---1、el-table 行加样式类名(row-class-name)生效了,但是效果检测不到;2、解决VUE项目在微信浏览器中使用支付宝支付提示复制链接到浏览器打开,bug,前端,vue,elementui,Powered by 金山文档

Android文章来源地址https://www.toymoban.com/news/detail-643033.html

每天bug---1、el-table 行加样式类名(row-class-name)生效了,但是效果检测不到;2、解决VUE项目在微信浏览器中使用支付宝支付提示复制链接到浏览器打开,bug,前端,vue,elementui,Powered by 金山文档

到了这里,关于每天bug---1、el-table 行加样式类名(row-class-name)生效了,但是效果检测不到;2、解决VUE项目在微信浏览器中使用支付宝支付提示复制链接到浏览器打开的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • el-table嵌套两层el-dropdown-menu导致样式错乱

    问题: 解决方式: 给菜单单独添加样式进行修改 最后效果:

    2024年01月18日
    浏览(54)
  • 【前端vue+elemenui】el-table根据表格数据设置整行样式或单元格样式

    首先需要了解俩个函数,row-class-name、cell-class-name 这里以cell-class-name单元格样式为例 row-class-name 行的 className 的回调方法,也可以使用字符串为所有行设置一个固定的 className。 Function({row, rowIndex})/String cell-class-name 单元格的 className 的回调方法,也可以使用字符串为所有单元

    2024年01月24日
    浏览(53)
  • Vue结合ElementUi修改<el-table>表格的背景颜色和表头样式

    修改table的表头背景 和 字体颜色: 以下是修改el-table表格内容的背景色和边框样式:

    2024年02月11日
    浏览(63)
  • 修改element-ui中的表格el-table的滚动条样式

    一.单独修改element-ui中的表格el-table的滚动条样式(两种方法) 1. 2.  二.保持整个页面的滚动条的风格是一致(直接改全局的滚动条样式) 三.页面内某一组件滚动条样式美化  scroll-bar是需要滚动条组件的元素,类名自定义

    2024年02月11日
    浏览(59)
  • 【Vue】在el-table的el-table-column中,如何控制单行、单列、以及根据内容单独设置样式。例如:修改文字颜色、背景颜色

    用cell-style表属性来实现。在官网中是这样表述这个属性的。    在el-table中用v-bind绑定此属性。(v-bind的简写是:) data中的options数据为: 此时页面显示为:     在methods中声明cellStyle方法。让我们打印出各个参数看一下代表了什么。 控制台打印如下:     其实很好理解,

    2024年02月15日
    浏览(59)
  • element-ui 表格el-table的列内容溢出省略显示,鼠标移上显示全部和定制样式

       1、在对应列加上省略显示show-overflow-tooltip属性,如果加上这属性,鼠标移上还是没效果,要考滤是不是层级的原因,被其他挡住了。    效果如下图: 2、定制样式: 默认提示框主题色是黑色,如果想改成浅色和改变提示框的宽度,则需要加复盖样式: 最后效果:

    2024年02月13日
    浏览(42)
  • 表格(el-table)里面嵌套表格(el-table)

    样式如下:   用到的代码: 一般需要嵌套表格这种情况下,后端返回的都是字符串格式的数组,需要在接收到数据后自己转化,编辑好提交的时候也需要自己把数组转为字符串格式传给后端. 一般在涉及到嵌套表格的情况下,新增或者编辑某条记录的时候,都会有动态增加或者删除一

    2024年02月15日
    浏览(39)
  • el-table实现纯前端导出(适用于el-table任意表格)

    2023.9.1今天我学习了如何使用el-table实现前端的导出功能,该方法的好处有无论你的el-table长什么样子,导出之后就是什么样子。 1.安装三个插件 npm install file-save npm install xlsx npm install xlsx-style 2.创建Export2Excel.js 3.按需引入 4.vue.config.js引入 效果: 扩展: 当我们会出现这样的表

    2024年02月10日
    浏览(50)
  • el-table 多选框改成单选框(el-table单选功能)

    今天,写项目时,有一个table作为筛选的载体,需要选中table里面的一条数据,我想了一下,用table里面的selection功能,实现单选功能。

    2024年02月16日
    浏览(46)
  • 【详解|彻底搞懂el-table和列表过滤】vue列表过滤和el-table的实现

    vue列表过滤 el-table的理解 先来看一段代码: chatGPT 的理解真的很6: 这段代码使用了 Element UI 的组件,创建了一个表格列组件 el-table-column,并为它设置了一些属性和插槽。 各种属性: 名称 作用 prop 指定了该列绑定的数据对象的属性名为 warehouseName label 指定了该列的列名为 “

    2024年02月11日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包