微信小程序|云环境共享-使用指南

最近上线了我的第三款小程序,自从有了AI后,每天有使不完的牛劲儿...

由于第一款个人小程序50天重启人生已开通了云开发,并且每月资源有富余,所以决定共享云环境资源,独立开发,能省则省...

即使有官方文档,但在开发中还是遇到了挺多问题,接下来就给大家梳理一下环境共享具体如何使用,以及一些注意点。

为了叙述方便,下文中将第一款小程序,也就是资源方统称为A,第二款小程序,也就是调用方称为B。

1. 开通「环境共享」:

开通流程按照官方文档操作就可以,操作成功后,A中打开云开发控制台如下图所示:

2. 调用云函数:

这里需要注意!!!你要调用的云函数要放在A项目中!

因为我B项目一开始使用的是本地免费云开发,所以云函数都在B项目中,我以为B项目中的云函数只要部署后效果是一样的。但开启环境共享后,再调用云函数一直提示没有权限,需要先开通云开发。所以这里需要将云函数都放置在A项目中:

之后就是在B项目的页面中调用云函数(这部分官方文档有,但刚开始没太整明白...):

这里无需在app.js中初始化云函数了,直接在具体js中使用

3. 注意事项:
  1. 项目B中如果要获取用户openid,要用FROM_OPENID
js 复制代码
// 云函数入口函数
exports.main = async (event, context) => {
  const wxContext = cloud.getWXContext();
  const { action, data } = event;
  // 获取用户openid
  const openid = wxContext.FROM_OPENID;
}
  1. 项目B中的image组件在环境共享中无法直接使用云储存中 cloud:// 协议的 fileID 加载图片:

解决方案: 在page下新增公共wxs文件,代码内容如下:

js 复制代码
// lib.wxs
module.exports = {
  getUrl: function (link) {
    if (link) {
    } else return "";
    if (link.substring(0, 5) == "cloud") {
    } else return link;
    var arr = link.split("/");
    arr[0] = "https:";
    arr[2] = arr[2].split(".")[1] + ".tcb.qcloud.la";
    return arr.join("/");
  },
};

页面中调用:

js 复制代码
<!-- pages/index/index.wxml -->
<wxs module="wxs" src="/pages/lib.wxs"></wxs>
<view>
   <image class="list-image" src="{{wxs.getUrl(item.image)}}" mode="aspectFill"></image>
</view>

完成以上配置与逻辑后,B项目就可以丝滑的共享云环境啦~。

最后,有任何小程序开发的问题,都欢迎评论区交流,也欢迎大家体验我的【理物收纳】小程序,一款简单易用的物品管理工具,让每一件物品都可视化,轻松记物,一目了然。

相关推荐
爱学习的程序媛42 分钟前
【Web前端】JavaScript设计模式全解析
前端·javascript·设计模式·web
小码哥_常1 小时前
从SharedPreferences到DataStore:Android存储进化之路
前端
老黑1 小时前
开源工具 AIDA:给 AI 辅助开发加一个数据采集层,让 AI 从错误中自动学习(Glama 3A 认证)
前端·react.js·ai·nodejs·cursor·vibe coding·claude code
jessecyj1 小时前
Spring boot整合quartz方法
java·前端·spring boot
苦瓜小生1 小时前
【前端】|【js手撕】经典高频面试题:手写实现function.call、apply、bind
java·前端·javascript
天若有情6732 小时前
前端HTML精讲03:页面性能优化+懒加载,搞定首屏加速
前端·性能优化·html
踩着两条虫2 小时前
AI驱动的Vue3应用开发平台深入探究(十):物料系统之内置组件库
android·前端·vue.js·人工智能·低代码·系统架构·rxjava
swipe2 小时前
AI 应用里的 Memory,不是“保存聊天记录”,而是管理上下文预算
前端·llm·agent
慧一居士2 小时前
nuxt3 项目和nuxt4 项目区别和对比
前端·vue.js
威联通安全存储3 小时前
破除“重前端、轻底层”的数字幻象:如何夯实工业数据的物理底座
前端·python