基于Vue框架,在微信H5页面创建订阅消息功能

服务号订阅通知按钮:wx-open-subscribe

注意事项和参数说明等,这些直接看官网 https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_Open_Tag.html#23

在vue 环境下,需要js 动态创建wx-open-subscribe 这个标签,不能按照官网的直接在页面里面写,

首选在页面你需要展示的地方写个dom元素

<div id="sub">
    这里是放订阅消息按钮的,标签id 会用到,通过找到这个元素,然后添加进来
</div>

然后就是js部分,在vue 的methods 方法里面写

// 创建订阅号
    	createSubscribeBut(){
    		let script = document.createElement('script')
				script.type = 'text/wxtag-template' 
				script.text = `<p class="mask-sub-btn" style="width: 200px;text-align: center;margin: 15px 0px;color: #fff;background-color: #00C553;border-radius: 50px;height: 40px;line-height: 40px;font-size: 14px;">点击订阅</p>`
// 创建订阅标签,把标签里面自定义的script标签内容插进去 
				let html = `<wx-open-subscribe template="NIGIMccEyV8M,MrtYqlJgDyh2ARYTs" id="share-success-subscribe-btn">${script.outerHTML}</wx-open-launch-weapp>`
				document.getElementById('share-success-sub-wrap').innerHTML = html;
				var subBtn = document.getElementById('share-success-subscribe-btn');
				this.watchSub(subBt);
    	},

// 监听订阅事件
    	watchSub(subBtn){
    		let templateIdArr = ['订阅消息的模板id','订阅消息的模板id'];
    		let _this = this;
    		subBtn.addEventListener('success', function (e) { 
					let tps = [];
                    // 这个订阅返回的参数不是正常的json 需要转
					let subdetail = JSON.parse(e.detail.subscribeDetails);
                    
					if( subdetail[templateIdArr[0]].indexOf('accept') !=-1){
						tps.push(templateIdArr[0])
					}
					if( subdetail[templateIdArr[1]].indexOf('accept') !=-1){
						tps.push(templateIdArr[1])
					}
                    // 用户点击订阅消息,但是取消订阅,这个时候直接不走后面代码
					if(!tps.length) return;
                    // 用户订阅了,就把订阅的模块id用逗号拼接下,传给后端,我这边是这样处理的,你根据后端接口需求来处理
					tps = tps.join();
    
                    //  发送ajax 请求 XXXXX
		            // 这里面可以写订阅成功的事件,把点击订阅得到的参数传给后台做记录
				
				});   
    	},

 下面给个案例展示

结束:如有不了解的可以留言,相互学习。

 生活不易,下面是我自己的小程序,看到的麻烦扫码打开给个支持啊,订阅通知,后面有福利活动会通知奥

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
Vue H5页面中实现微信分享,可以按照以下步骤进行: 第一步,获取微信分享所需的相关配置: 在Vue项目中引入微信开放平台的JS-SDK,然后通过微信开放平台接口获取到当前页面的分享配置信息,包括标题、描述、链接和图片等信息。 第二步,调用微信JS-SDK进行分享: 在Vue的组件中,通过引入微信JS-SDK提供的方法,如`wx.onMenuShareTimeline`和`wx.onMenuShareAppMessage`等,来实现对应的分享功能。可以将这些方法封装成一个单独的util文件,方便在项目中多次调用。 第三步,配置分享参数: 调用微信JS-SDK的分享方法前,需要将获取到的分享配置信息传入相应的参数中,如标题、链接、描述和分享图等。可以根据当前页面的不同内容来动态设置分享的参数。 第四步,设置微信签名: 在Vue页面中,可以使用`vue-router`插件进行路由控制,当进入到需要分享的页面时,通过异步请求来获取当前页面的分享配置信息和签名,然后将签名设置给微信JS-SDK。 第五步,调用分享方法: 在上面的配置完成后,即可通过微信JS-SDK提供的分享方法,如`wx.onMenuShareTimeline`和`wx.onMenuShareAppMessage`等,来实现对应的分享功能。可以按需选择分享到朋友圈、发送给好友或分享到QQ等渠道。 需要注意的是,Vue H5页面在与微信分享时,由于所处的环境和限制会有所不同,可能需要在不同的事件中触发分享,比如在路由切换完成后触发分享方法。 以上是实现Vue H5页面分享微信的一般步骤,具体实现还需要根据项目的需求和微信开放平台的接口文档进行调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CjBkl

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值