在Vue中调用微信的扫描二维码功能

步骤

  • 新建vue文件(这里采用mint的标签库--就一个按钮~~)
  • 关键代码

    <template>
        <div class="login_div">
            <mt-button id="wxsys" type="primary" v-on:click="sys_click()">扫一扫</mt-button>
        </div>
    </template>
    <script>
        import wx from 'weixin-js-sdk'
        import $ from 'jquery'
        export default {
            data(){
                return {
                }
            },
        methods : {
            sys_click : function()
            {
            //这里【url参数一定是去参的本网址】
            $.get("获取微信认证参数的地址?url=去参的本网页地址", function(data){
            var jsondata=$.parseJSON(data);
                wx.config({
                    // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
                    debug: false,
                    // 必填,公众号的唯一标识
                    appId: jsondata.model.appId,
                    // 必填,生成签名的时间戳
                    timestamp: "" + jsondata.model.timestamp,
                    // 必填,生成签名的随机串
                    nonceStr: jsondata.model.nonceStr,
                    // 必填,签名
                    signature: jsondata.model.signature,
                    // 必填,需要使用的JS接口列表,所有JS接口列表
                    jsApiList: ['checkJsApi', 'scanQRCode']
                });
            });
            wx.error(function (res) {
                alert("出错了:" + res.errMsg);//这个地方的好处就是wx.config配置错误,会弹出窗口哪里错误,然后根据微信文档查询即可。
            });
    
            wx.ready(function () {
                wx.checkJsApi({
                    jsApiList: ['scanQRCode'],
                    success: function (res) {
    
                    }
                });
    
                    wx.scanQRCode({
                        needResult: 1, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
                        scanType: ["qrCode"], // 可以指定扫二维码还是一维码,默认二者都有
                        success: function (res) {
                            var result = res.resultStr; // 当needResult 为 1 时,扫码返回的结果
                            alert("扫描结果:"+result);
                            window.location.href = result;//因为我这边是扫描后有个链接,然后跳转到该页面
                        }
                    });
    
            }); 
            }
    
        }
    }
    </script>
    

Vue引入微信的sdk和jquery需要做:

  • 引入微信sdk
    • 安装依赖 npm i -S weixin-js-sdk
    • 引入 import wx from 'weixin-js-sdk'
  • 引入jquery

注意事项:

  • “获取微信认证参数”
    • 这个的前提是您能够有自己的微信开发资质,并能获取到正确的参数
      1. 公众号的唯一标识
      2. 签名的时间戳
      3. 签名随机串
  • 常见的错误
    • config:invalid signature
  • 解决办法
    • “当前网页的地址”-----哈哈,一定是你写的不对,这里一定是去参的本网页的地址
    • 最好是在服务器下去测试

其他问题暂时没有,希望对有缘人有帮助~~


Logo

前往低代码交流专区

更多推荐