微信小程序右上角分享按钮如何根据用户登录状态确定是否允许分享

微信小程序右上角分享按钮如何根据用户登录状态确定是否允许分享

问题描述

微信小程序的分享功能,即在js文件中加入onShareAppMessage()方法即可点亮右上角的分享按钮。这满足一航情况下的使用。但如果分享的条件加上登录之后才能分享。这个方法就不好使了。

问题分析

点击分享后,小程序会优先使用onShareAppMessage()中return出来的对象为数据,当没找到对应的对象时,会使用默认的值。那如果判断出当前用户没有登录,该怎么取消当前的分享弹出框呢? 此时,我试过return值false,null,undefined,0都不行。

绕过强行弹框

先看看下面的的代码:

javascript 复制代码
Page({
		onShareAppMessage: function (t) {
		   var a = this, e = getApp().getUser(), path = "/pages/index/index", title, query_arr = [], query_str;
        let imageUrl = `${a.data.__siteroot}statics/images/share-home.jpg`;

        // 未登录提示框
        a.checkAndShowLoginModal();

        if (e.id) {
            getApp().page.onShareAppMessage(this);
            query_arr.push({ user_id: e.id });
        }
        
        title = a.data.store.name;
        
        // 组装参数
        query_str = getApp().helper.objectArrayToQueryString(query_arr);
        path += `?${query_str}`;

        const promise = new Promise(resolve => {
            setTimeout(() => {
                resolve(null);
            }, 2000);
        });
        // 已登录
        if (e.id) {
            return {
                path,
                title,
                imageUrl: imageUrl,
                scene: 0,
            };
        } else {
            return {
                promise
            };
        }
    },
})

以上代码当判断出用户未登录时,会弹出未登录提示,并避免了系统的分享框的弹出。

核心代码

利用onShareAppMessage() 的promise 机制,给resolve赋null或undefined值,注意,不是字符串。

javascript 复制代码
const promise = new Promise(resolve => {
    setTimeout(() => {
        resolve(null);
    }, 2000);
});
// 已登录
if (e.id) {
    return {
        path,
        title,
        imageUrl: imageUrl,
        scene: 0,
    };
} else {
    return {
        promise
    };
}

为什么成功绕过了

先来看看未登录时点分享按钮发生了什么,此时走的是带有promise的对象:

javascript 复制代码
// 未登录时
return {
   promise
}
shell 复制代码
onShareAppMessage error  TypeError: Cannot read property 'title' of null
	at VM7634 WASubContext.js:1

调试显示错误信息:无法在null中读取到title属性,导致分享弹框无正常显示,也就成功绕过了。

这不是官方提供的方法,是利用了分享接口接收resolve的特性使系统执行的弹窗失效了,腾讯未来会不会封堵或直接提供回调拦停弹框方法,我们拭目以待。

相关推荐
2501_915921432 小时前
iOS 描述文件制作过程,从 Bundle ID、证书、设备到描述文件生成后的验证
android·ios·小程序·https·uni-app·iphone·webview
小白学大数据2 小时前
基于 Python 的知网文献批量采集与可视化分析
开发语言·爬虫·python·小程序
毕设源码-郭学长2 小时前
【开题答辩全过程】以 基于微信小程序的医院管理系统为例,包含答辩的问题和答案
微信小程序·小程序
毕设源码-朱学姐2 小时前
【开题答辩全过程】以 基于微信小程序的医疗物资进销存管理为例,包含答辩的问题和答案
微信小程序·小程序
低代码布道师4 小时前
教培管家第06讲:搭建销售工作台——公海争夺与私海管理
低代码·小程序·云开发
柚鸥ASO优化6 小时前
抢占流量入口:小程序名称与关键词的优化指南
小程序
说私域6 小时前
基于链动2+1模式S2B2C商城小程序的营销策略创新与品牌发展研究
小程序·产品运营·流量运营
qq_12498707536 小时前
基于Spring Boot的心理咨询预约微信小程序(源码+论文+部署+安装)
java·spring boot·后端·spring·微信小程序·小程序·毕业设计
说私域6 小时前
AI智能名片S2B2C商城小程序品牌诞生原因与发展历程分析
人工智能·小程序·流量运营