uniapp —— 小程序实现带参分享微信、朋友圈以及调试获取参数

12 篇文章 0 订阅
5 篇文章 3 订阅

uniapp —— 小程序实现带参分享微信、朋友圈以及调试获取参数

零、起因以及分类

  1. 小程序
    我们在开发微信小程序的过程中,经常需要实现分享给微信用户或者分享到微信朋友圈的功能,基本上我们会用到 onShareAppMessage 这个处理函数《传送地址》,我们先看看他的支持情况:
    支持情况
    我们可以看到其实除了小程序之外,AppH5 是不被支持的,那么这两种用户端需要如何实现分享呢?
  2. App
    App 端我们则是使用 uni.share() 这个处理函数《传送地址》,他的API比较丰富,支持的情况也多样化:
    支持情况
  3. H5
    H5 端做微信分享,没有任何官方API的支持,但也不是完全没有办法。我们需要用到微信的 jssdk ,还需要配置 js接口安全域名 ,我们可以借助 jweixin-module 工具包来辅助开发,需要的小伙伴们自行百度把~ 今天主要研究微信小程序的分享。

一、封装公共文件

我们于项目根目录的 common 中,新建 commonShare.js 文件:

export default {
	data() {
		return {
			shareParams: {
				path: '/pages/index/index?user_id=100',
				title: '邀请您成为新用户'
			}
		}
	},
	onShareAppMessage(res) {
		if (res.from === 'button') {
			// 来自页面内分享按钮
			console.log(res.target);
		}
		return {
			title: this.shareParams.title, // 标题
			path: this.shareParams.path, // 分享路径
			imageUrl: 'https://cdn.uviewui.com/uview/swiper/1.jpg', // 分享图
			desc: '小程序描述描述描述描述'
		};
    },
	onShareTimeline() {
		return {
			title: this.shareParams.title, // 标题
			path: this.shareParams.path, // 分享路径
			imageUrl: 'https://cdn.uviewui.com/uview/swiper/1.jpg'// 分享图
		};
	}
}

二、混入所有页面

我们于 main.js 文件中,执行混入:

// 混入分享js
import commonShare from '@/common/commonShare.js'
Vue.mixin(commonShare)

三、触发条件

  1. button 触发
    使用 open-type="share" 可以触发分享至微信事件,注意,button按钮无法触发分享到朋友圈事件
<button open-type="share">分享到微信</button>
  1. 胶囊按钮触发
    胶囊按钮的更多选项,可以选择触发分享至微信,也可以选择分享到朋友圈:
    胶囊按钮触发分享

四、调试

  1. 没有混入公共分享文件之前:
    混入之前
  2. 混入公共分享文件之后:
    混入之后
    点击发送给朋友的效果:
    发送给朋友
    点击分享到朋友圈的效果:
    分享至朋友圈的效果i
  3. 调试参数,我们先在分享页面中预先打印参数:
onLoad(options) {
	console.log('user_id:' + options.user_id);
}

然后添加三种编译模式,模拟三种应用场景,分别测试是否能获取得到参数:

  • 由微信聊天点击进来的场景
    场景1
    聊天获取参数成功
  • 由朋友圈广告点击进来的场景
    场景2
    朋友圈广告进来获取参数成功
  • 由朋友圈分享详情页点击进来的场景
    场景3
    朋友圈详情页进来获取参数成功
  • 6
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值