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

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

问题描述

微信小程序的分享功能,即在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的特性使系统执行的弹窗失效了,腾讯未来会不会封堵或直接提供回调拦停弹框方法,我们拭目以待。

相关推荐
cosinmz1 天前
图片太多太乱怎么整理?分享一个我最近常用的图片转 PDF方法
经验分享·小程序·pdf
科技互联.1 天前
2026年小程序定制市场:个性化需求激增,技术深度成竞争关键
人工智能·小程序
小羊Yveesss2 天前
2026年小程序商城的现状和发展趋势
小程序
Greg_Zhong2 天前
微信小程序如何关闭:当前渲染模式为webview?
微信小程序·微信小程序渲染引擎·渲染引擎需搭配更高基础库
橘子海全栈攻城狮2 天前
【最新源码】养老院系统管理A013
java·spring boot·后端·web安全·微信小程序
智慧景区与市集主理人2 天前
五一市集分账混乱?巨有科技智慧市集小程序实现统一收款、自动分账
大数据·科技·小程序
程序鉴定师2 天前
深圳小程序制作哪家好?2026深度市场分析与选择指南?
大数据·小程序
河北清兮网络科技2 天前
广告联盟全解析:从开发接入到运营优化,多视角拆解流量变现逻辑
小程序·app
计算机学姐2 天前
基于微信小程序的校园失物招领管理系统【uniapp+springboot+vue】
java·vue.js·spring boot·mysql·信息可视化·微信小程序·uni-app
张晓℡¹⁸⁰³⁷¹⁸²⁵⁵⁸2 天前
海外盲盒APP玩法集合,海外盲盒多国语言
小程序·php