DCloud_UNI_GSQ
DCloud_UNI_GSQ
  • 发布:2018-12-18 13:52
  • 更新:2022-11-19 16:28
  • 阅读:238643

UNI-APP 开发微信公众号(H5)JSSDK 的使用方式

分类:uni-app

uni-app 中为兼容微信小程序生态存在全局的 wx 对象,而微信 JS-SDK 也是注册全局的 wx 对象,为避免混淆,可以将微信 JS-SDK 中的 wx 对象改名。采用以下两种方案之一即可。

方案一:模块化

在 uni-app 中可以使用模块方式引用微信 js-sdk ,可以避免与 uni-app 内置 wx 全局对象冲突的问题。

微信官网直接下载的如果使用有问题,可以使用 jweixin-module

安装

- NPM安装方式(不会用NPM就不要用这种方式)

npm install jweixin-module --save

- 下载使用方式

下载地址:https://unpkg.com/jweixin-module@1.6.0/lib/index.js

使用

var jWeixin = require('jweixin-module')  
jWeixin.ready(function(){  
    // TODO  
});

方案二:全局引入

如果不使用模块化引入 JS-SDK,而采用传统方式在 html 模板中直接全局引入,可以修改全局变量名称。

<!DOCTYPE html>  
<html lang="zh-CN">  
    <head>  
        <meta charset="utf-8">  
        <meta http-equiv="X-UA-Compatible" content="IE=edge">  
        <title>  
            <%= htmlWebpackPlugin.options.title %>  
        </title>  
        <!-- Open Graph data -->  
        <!-- <meta property="og:title" content="Title Here" /> -->  
        <!-- <meta property="og:url" content="http://www.example.com/" /> -->  
        <!-- <meta property="og:image" content="http://example.com/image.jpg" /> -->  
        <!-- <meta property="og:description" content="Description Here" /> -->  
        <script>  
            var coverSupport = 'CSS' in window && typeof CSS.supports === 'function' && (CSS.supports('top: env(a)') || CSS.supports('top: constant(a)'))  
            document.write('<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0' + (coverSupport ? ', viewport-fit=cover' : '') + '" />')  
        </script>  
        <script src="http://res.wx.qq.com/open/js/jweixin-1.6.0.js"/>  
        <script>  
            window.jWeixin=window.wx;  
            delete window.wx;  
        </script>  
        <link rel="stylesheet" href="<%= BASE_URL %>static/index.<%= VUE_APP_INDEX_CSS_HASH %>.css" />  
    </head>  
    <body>  
        <noscript>  
            <strong>Please enable JavaScript to continue.</strong>  
        </noscript>  
        <div id="app"></div>  
        <!-- built files will be auto injected -->  
    </body>  
</html>

完整API

微信JS-SDK说明文档

33 关注 分享
Trust GCJ 五叶神 虫雪浓 少年时 7***@qq.com e***@163.com 6***@qq.com z***@ichengyue.cn 1***@qq.com sonicsunsky 漩涡鸣人 战力不足五 zting590 叶冬凌 lydeon 屁小孩 w***@163.com Charlee丶毒 q***@icloud.com 天保 厘米 你的益达007 君不见 5***@qq.com 8***@qq.com rysnone 2***@qq.com 苏陌 l***@163.com 2***@qq.com 2***@qq.com 小答

要回复文章请先登录注册

Megasu

Megasu

Mark 标记一下:《UNI-APP 开发微信公众号(H5)JSSDK 的使用方式》
2022-11-19 16:28
Megasu

Megasu

Mark 标记一下~
2022-11-19 16:27
易软

易软

回复 易软 :
如果 说动态引入js的话 在安卓需要将 window.wx = window.jWeixin;ios可以不用就能在安卓和ios取到 angetConfig,但是ios端选图片就返回的是paths不是id了,如果ios和安卓都动态引入并且将window.wx = window.jWeixin,ios拍照是返回了id但是取不到angentConfig啊!
2022-11-17 18:29
易软

易软

亲 企业微信 好像不能用1.6.0的版本的,现在还是安卓没问题,ios 取不到 wx.agentConfig啊 一直提示undefined
2022-11-17 18:27
1***@qq.com

1***@qq.com

domain is not defined 怎么解决
2022-11-07 22:11
2***@qq.com

2***@qq.com

回复 g***@163.com :
请问具体是怎么操作的呢,我是在script上加了async属性,但是安卓端还是调用不了扫码
2022-10-13 14:57
g***@163.com

g***@163.com

回复 DCloud_UNI_GSQ :
没用,在浙里办微信小程序环境这个JS会读另一个JS,然后再改写wx对象,把ZWJSBridge.js改成异步加载就解决问题了
2022-09-09 15:17
我一笑而过

我一笑而过

@DCloud_UNI_GSQ 想问下,我在微信开发者工具中测试我本地的网页,页面始终报config:fail,invalid signature,相同的页面生产环境却是正常的,是本地环境不能调用微信jssdk的方法吗?
2022-08-30 16:17
羊仔

羊仔

回复 1***@qq.com :
看接口权限里(apilist)有没有这个
2022-08-24 16:03
DCloud_UNI_GSQ

DCloud_UNI_GSQ (作者)

回复 g***@163.com :
打开sdk文件,如果里面是固定的wx,需要修改一下改成jWeixin。
2022-08-24 15:36