关于H5页面在微信端的分享

微信分享,咋一看好像很复杂,实则非常简单。只需要调用微信官方出的微信jssdk,加上些许配置,就可以实现h5页面在微信上的分享,官方文档地址为:

https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115

 

一、获取基本信息

 

找到已有公众号的appid,根据这个appid和url向后端发起请求,拿到配置所需要的参数:timestamp、noncestr和signature。

 

二、实现

 

1、页面引入JS-SDK文件

 

通过script标签,引入微信官网的JS-SDK文件

1b9e166ecd684021bc00eca469bd91e3.png

2、基本配置

743a06a6447f4093bc57f20287c9d19d.png

3、使用

f25a2ae100d241cfa9fe6541afe2c7c9.png

 

三、调试

 

wx.config里的debug字段设置为true时,就可以进行调试。

 

调试要用到微信开发者工具,选择公众号网页项目,输入页面地址就可以了。

 

四、遇到的问题及解决方案

 

微信JS-SDK说明文档的附录5里有大部分问题的解决方案,在这里我列出我遇到的几个上面没有给出解决方案的。

 

1、Uncaught TypeError: Cannot read property 'config' of undefined

解决:html页面单独引入了sdk,并且组件统一也引入了一遍sdk,导致问题,删除其中之一。

2、Uncaught (in promise) TypeError: Cannot read property 'ready' of undefined

解决:同问题1。

3、invalid signature

 

解决:如果文档里的方法都没有解决这个问题,还有一种方法,先设置一种最基础的配置,使其config ok,然后再设置一遍自己需要的有各种参数的分享文案,这样能绕过配置,成功分享。说的可能有点拗口,简单点理解就是,页面只要有一个config成功的配置,就可以再继续配置其它分享,哪怕这个分享配置的signature无效。

 

编辑:千锋HTML5

作者:stardew

来源:https://segmentfault.com/a/1190000016199418

在Uniapp中实现微信分享,可以通过以下步骤进行: 1.在 manifest.json 文件中配置微信分享所需的权限: ``` { "mp-weixin": { "appid": "你的微信公众号appid", "permission": { "scope.userLocation": { "desc": "你的位置信息将用于小程序位置接口的效果展示" }, "scope.userInfo": { "desc": "你的用户信息将用于小程序内部展示" }, "scope.record": { "desc": "你的录音功能将用于小程序内部展示" }, "scope.writePhotosAlbum": { "desc": "你的相册将用于小程序内部展示" }, "scope.camera": { "desc": "你的摄像头将用于小程序内部展示" }, "scope.userLocationBackground": { "desc": "你的位置信息将用于小程序位置接口的效果展示" }, "scope.werun": { "desc": "你的微信运动数据将用于小程序展示" }, "scope.invoice": { "desc": "你的发票信息将用于小程序展示" }, "scope.invoiceTitle": { "desc": "你的发票抬头信息将用于小程序展示" }, "scope.record": { "desc": "你的录音功能将用于小程序展示" }, "scope.writePhotosAlbum": { "desc": "你的相册将用于小程序展示" } }, "window": { "navigationBarBackgroundColor": "#ffffff", "navigationBarTitleText": "uni-app", "navigationBarTextStyle": "black", "backgroundTextStyle": "dark", "backgroundColor": "#F7F7F7" }, "networkTimeout": { "request": 60000, "downloadFile": 60000 }, "tabBar": { "selectedColor": "#007AFF", "backgroundColor": "#ffffff", "color": "#999999", "borderStyle": "black", "list": [ { "pagePath": "pages/index/index", "text": "首页", "iconPath": "static/tabbar/home.png", "selectedIconPath": "static/tabbar/home-active.png" }, { "pagePath": "pages/my/my", "text": "我的", "iconPath": "static/tabbar/my.png", "selectedIconPath": "static/tabbar/my-active.png" } ] }, "plugins": { "myPlugin": { "version": "1.0.0", "provider": "wxidabcdefg" } }, "preloadRule": { "async": "networkFirst", "sync": [ "pages/index/index" ], "custom": { "name": "my-custom-name", "path": "path/to/my/custom-module" } }, "sitemapLocation": "sitemap.json", "debug": true, "workers": { "path": "static/js/worker.js", "clear": true }, "requiredBackgroundModes": [ "audio", "download", "location", "fetch", "video" ], "navigateToMiniProgramAppIdList": [ "wx1234567890abcdef", "wx0987654321zyxwvu" ], "usingComponents": { "my-custom-component": "/static/my-custom-component" }, "permission": { "scope.userLocation": { "desc": "你的位置信息将用于小程序位置接口的效果展示" }, "scope.userInfo": { "desc": "你的用户信息将用于小程序内部展示" }, "scope.record": { "desc": "你的录音功能将用于小程序内部展示" }, "scope.writePhotosAlbum": { "desc": "你的相册将用于小程序内部展示" }, "scope.camera": { "desc": "你的摄像头将用于小程序内部展示" }, "scope.userLocationBackground": { "desc": "你的位置信息将用于小程序位置接口的效果展示" }, "scope.werun": { "desc": "你的微信运动数据将用于小程序展示" }, "scope.invoice": { "desc": "你的发票信息将用于小程序展示" }, "scope.invoiceTitle": { "desc": "你的发票抬头信息将用于小程序展示" }, "scope.record": { "desc": "你的录音功能将用于小程序展示" }, "scope.writePhotosAlbum": { "desc": "你的相册将用于小程序展示" } } } } ``` 2.在需要分享页面中调用微信分享的 API: ``` export default { onShareAppMessage() { return { title: '分享标题', path: '/pages/index/index', imageUrl: 'http://example.com/share.png' } } } ``` 其中,`title` 表示分享的标题,`path` 表示分享的路径,`imageUrl` 表示分享的图片链接。根据需要进行修改即可。 3.在微信公众平台中配置网页授权域名和JS接口安全域名。 以上就是实现 Uniapp h5微信分享的步骤。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值