微信小程序onShareAppMessage 分享-生命周期函数 在vue3中 组合式函数 hooks中不生效

onShareAppMessage是微信小程序比较常用的分享功能函数,今天我想着写到hooks里面,这样更方便调用和维护,分享一下错误写法跟正确写法;

错误写法

1、直接将share给return出去
javascript 复制代码
import { onShareAppMessage } from "@dcloudio/uni-app";

interface ShareOptions {
    title?: string;
    path?: string;
    imageUrl?: string;
}

export function useShareView() {

    const share = ({ title = '商城', path = '/pages/index/index', imageUrl = '' }: ShareOptions = {}) => {
        onShareAppMessage(() => {
            return {
                title,
                path,
                imageUrl,
            };
        });
    }


    return share 
}
2、跟onLoad等其他生命周期一样,直接调用一下onShareAppMessage函数
TypeScript 复制代码
import { onShareAppMessage } from "@dcloudio/uni-app";

interface ShareOptions {
    title?: string;
    path?: string;
    imageUrl?: string;
}

export function useShareView({ title = '商城', path = '/pages/index/index', imageUrl = '' }: ShareOptions = {}) {

 
        onShareAppMessage(() => {
            return {
                title,
                path,
                imageUrl,
            };
        });
    


}

我觉得两种办法都没错,但是都不可以,我就去找文档和社区记录,想着可能是uni自己的坑,不允许onShareAppMessage这个api这样调用,但是onLoad等生命周期都可以通过组合示函数被使用,我找到了一个uni-app的bug修复记录;

社区记录 这个bug已经被修复,而且已经很早了,那么只能是用法的原因,我只能尝试其他办法,可能是这个onShareAppMessage这个api比较特殊,它不只是生命周期,还具有页面分享的配置。

3、正确用法,onShareAppMessage函数名称的特殊性

最后我把share又赋值给onShareAppMessage这个名称,这个api可以正确被注册和使用了。

TypeScript 复制代码
import { onShareAppMessage } from "@dcloudio/uni-app";

interface ShareOptions {
    title?: string;
    path?: string;
    imageUrl?: string;
}

export function useShareView() {

    const share = ({ title = '商城', path = '/pages/index/index', imageUrl = '' }: ShareOptions = {}) => {
        onShareAppMessage(() => {
            return {
                title,
                path,
                imageUrl,
            };
        });
    }


    return { onShareAppMessage: share }
}

还有一个小心得记录,我传参习惯了使用解构的方式,这样多参数传参不用去按顺序传参,更方便;今天看ai写,它这样写,也实现了同样的传参功能,还是第一次见;自从用ai以来,很少时间去看新的一些特性,也不知道是新特性 还是我没关注过,哈哈,也记录一下。

TypeScript 复制代码
 function share(  
        options: {  
            title?: string  
            path?: NavPageName  
            imageUrl?: string  
        } = {}  
    ) {  
        onShareAppMessage(() => options)  
    }  
总结(ai都没解决的问题):我使用gpt5.3-codex模型,ai也没有正确解决这个问题

还是因为onShareAppMessage这个生命周期的特殊性,必须使用onShareAppMessage函数名 才可以被正确识别,也是一个不大不小的坑,记录一下。

相关推荐
蜗牛前端18 小时前
codex 全流程开发上线的高颜值礼簿小程序
前端·微信小程序
爱勇宝5 天前
我想认真做一件小事:让孩子和家长更好地互动
微信小程序·小程序·云开发
唯火锅不可辜负5 天前
避坑指南:iOS 下 scroll-view 嵌套 fixed 布局的“翻车”现场与修复
微信小程序
didiplus5 天前
运维人的随身神器:我把25个常用工具塞进了微信小程序
微信小程序
一份执念5 天前
uni-app 小程序分包限制处理与主包体积优化实战
前端·微信小程序
一份执念5 天前
ECharts 安装与使用完全指南:从全量引入到小程序分包优化
微信小程序·echarts
skiyee7 天前
🔥UniApp 仅需 5 行代码!实现所有页面中控制应用主题变化
前端·微信小程序
Jinkey8 天前
要用户手机号真的是为了打骚扰电话吗?浅谈微信生态会员账号体系与资产合并
后端·微信·微信小程序
用户43242810611410 天前
微信小程序从0到1接入微信支付的完整攻略
微信小程序
spmcor12 天前
微信小程序 setStorageSync 踩坑实录:别让"顺手一存"变成"隐形炸弹"
微信小程序