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

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

问题描述

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

相关推荐
蓝帆傲亦30 分钟前
支付宝小程序性能暴增秘籍:UniApp项目极限优化全攻略
小程序·uni-app
CHU7290355 小时前
淘宝扭蛋机抽盒小程序前端功能解析:解锁趣味抽盒新体验
前端·小程序
2501_933907217 小时前
深圳本凡科技专业企业APP开发,助力手机应用创新优化
科技·微信小程序·小程序
每天都要加油呀!8 小时前
TypeError: uni.requestPayment is not a function
小程序
java1234_小锋9 小时前
分享一套优质的微信小程序校园志愿者系统(SpringBoot后端+Vue3管理端)
微信小程序·小程序·校园志愿者
2501_9160088910 小时前
深入解析iOS机审4.3原理与混淆实战方法
android·java·开发语言·ios·小程序·uni-app·iphone
打破砂锅问到底00710 小时前
AI 驱动开发实战:10分钟从零构建「微信群相册」小程序
人工智能·微信·小程序·ai编程
CHU72903511 小时前
扭蛋机盲盒小程序前端功能设计解析:打造趣味与惊喜并存的消费体验
前端·小程序
QT.qtqtqtqtqt11 小时前
uni-app小程序前端开发笔记(更新中)
前端·笔记·小程序·uni-app
CHU72903513 小时前
直播商城APP前端功能全景解析:打造沉浸式互动购物新体验
java·前端·小程序