uni-app 实现微信小程序全局页面分享功能教程

🚀 uni-app 实现微信小程序全局页面分享功能教程

💡 整理不易,欢迎收藏、点赞、关注!

在开发微信小程序时,为每个页面添加“分享给好友”或“分享到朋友圈”能力是常见需求。手动在每个页面编写 onShareAppMessage 代码既重复又易错。本文将教你如何通过 mixin 实现一次配置、所有页面自动支持分享,并支持国际化。


🧩 一、核心方案:全局混入分享逻辑

✅ 使用 app.mixin() 注入分享钩子

main.tsmain.js 中(你是 SSR 模式,通常是 main.ts 中的 createApp() 函数里),写入以下逻辑即可让所有页面具备分享能力。

📦 示例代码(含国际化)

// main.ts 或 main.js
import { createSSRApp } from "vue";
import { bootstrap } from "/@/cool/bootstrap";
import App from "./App.vue";
import { i18n } from "./locale"; // 引入国际化配置
import "./router"; // 引入路由

export function createApp() {
  const app = createSSRApp(App);

  // 全局混入分享逻辑
  app.mixin({
    // 分享给好友
    onShareAppMessage() {
      return {
        title: i18n.global.t("share.title"), // 使用 i18n 国际化
        path: "/pages/index/index", // 默认跳首页
        imageUrl: "/static/share.png", // 可选分享图片
      };
    },
    // 分享到朋友圈
    onShareTimeline() {
      return {
        title: i18n.global.t("share.title"),
        query: "",
        imageUrl: "/static/share.png",
      };
    },
  });

  // 启用国际化
  app.use(i18n);

  // 自定义系统启动逻辑
  bootstrap(app);

  return {
    app,
  };
}

🌐 二、支持国际化标题配置

你已经启用了多语言,分享标题也可跟随语言变化。建议在语言文件中增加 share.title 字段:

🌍 示例:语言包配置

// locale/zh-CN.ts
export default {
  share: {
    title: "合作伙伴系统"
  }
};

// locale/en-US.ts
export default {
  share: {
    title: "Partner System"
  }
};

🧩 三、页面级别支持自定义分享(可选)

你可以在某些页面手动重写默认分享内容:

<script setup>
defineOptions({
  onShareAppMessage() {
    return {
      title: "当前页面自定义分享标题",
      path: "/pages/detail/index?id=123"
    };
  }
});
</script>

🎯 四、支持按钮触发分享

微信小程序支持通过按钮触发分享:

<view>
  <button open-type="share">点击分享给好友</button>
</view>

注意:只有页面定义了 onShareAppMessage 才能显示并生效该按钮。


📌 五、扩展建议(进阶)

你可以结合当前页面路径,实现自动动态 path:

onShareAppMessage() {
  const pages = getCurrentPages();
  const current = pages[pages.length - 1];
  const route = current.route;
  const options = current.options || {};
  const query = Object.keys(options)
    .map((key) => `${key}=${options[key]}`)
    .join("&");

  return {
    title: i18n.global.t("share.title"),
    path: `/${route}?${query}`,
    imageUrl: "/static/share.png",
  };
}

✅ 总结

  • 你已成功使用 app.mixin() 为所有页面添加了分享能力。
  • 支持 onShareAppMessageonShareTimeline
  • 可配合 i18n 进行国际化。
  • 局部页面可手动重写,灵活可控。
  • 支持通过按钮 open-type="share" 触发分享。
uni-app提供了内置的微信分享API,可以通过调用相关方法来实现微信小程序分享功能。首先,在onLoad方法中使用wx.showShareMenu方法,设置menus将发送给朋友和分享到朋友圈两个按钮都可以点击。具体代码如下: ```javascript onLoad() { wx.showShareMenu({ withShareTicket: true, menus: \["shareAppMessage", "shareTimeline"\] }) } ``` 接下来,需要分别编写发送给朋友和分享到朋友圈的方法。这两个方法应该与data和methods等同级,不要写到methods里面。具体代码如下: ```javascript onShareAppMessage(res) { if (res.from === 'button') { console.log(res.target) } return { title: 'title', path: '/pages/hfdt/gztjh', mpId: 'wx6bf107b87c455b99' } }, onShareTimeline(res) { return { title: '胶南街道召开“红帆支部”观摩学习暨工作推进会', type: 0, summary: "" } } ``` 在onShareAppMessage方法中,可以设置分享的标题、路径和微信小程序AppId。在onShareTimeline方法中,可以设置分享到朋友圈的标题和类型等信息。通过以上步骤,就可以实现uni-app微信小程序分享功能。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [uniapp 微信分享](https://blog.youkuaiyun.com/lxgyydsgod/article/details/126234984)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [uniapp微信小程序使用分享功能](https://blog.youkuaiyun.com/qq_43080548/article/details/125619531)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值