内容简介:是的,参考兼容性问题进行配置。可以在小程序端和服务端调用。小程序端是通过内置的接口调用。而服务端,这里包括原有的服务和云函数,可以通过
小程序·云开发 文档里,则是所有与小程序·云开发相关的文档内容。下面会通过用户关心的的一些问题,介绍在哪里可以找到对应的文档。
1. 云开发是可以用于所有的小程序基础库吗?
是的,参考兼容性问题进行配置。
2. 云开发的服务,可以在哪些端被调用?不同端会有哪些的调用能力的不同?
可以在小程序端和服务端调用。小程序端是通过内置的接口调用。而服务端,这里包括原有的服务和云函数,可以通过 wx-server-sdk 或者 tcb-admin-node 其中一个 node sdk 进行调用,前者是基于后者进行二次开发的。如果希望开发体验与小程序端一致,可采用 wx-server-sdk 。小程序端的调用由于安全问题,会由较多的限制,而在服务端,则是可拥有管理员的权限(所以你会发现 tcb-admin-node 带有 admin 字眼,表示具有管理员权限)。
小程序端的 API 文档,可在小程序端 API 文档 查看。
服务端的 API 文档,可在 云开发 Server API 文档 查看。
3. 在自己的服务器或者电脑本地的Node运行环境里(不是云开发)调用云开发的服务,要做哪些额外配置。
需要填入腾讯云的 SecretId 和 SecretKey 。通过此链接登录小程序对应的腾讯云帐号,然后在云API密钥 里获取。
云API密钥
获取密钥后,可使用 tcb-admin-node ,在你的服务器里调用云开发的服务。
// 初始化示例
const cloud = require('tcb-admin-node');
// 初始化资源
// 云函数下不需要 secretId和secretKey,但如果在自己的服务器里使用则需要
// env如果不指定将使用默认环境
cloud.init({
secretId: '',
secretKey: '',
});
// 获取所有数据的方法
async function getData(colName) {
const db = cloud.database();
const userCollection = db.collection(colName);
// 统计数据总量
let res = await userCollection.count();
let total = res.total;
let data = [];
let length = 0;
let start = 0;
// 循环将数据读出来
while (total > length) {
let res = await userCollection.skip(start).get();
// 读出来后将数据存到data里
data = data.concat(res.data);
length += res.data.length;
start += length;
}
return data;
}
getData('users').then((data) => {
console.log(data);
}); // 调用方法复制代码
4. 云函数的创建和依赖安装。
在 project.config.json 文件里,要添加以下字段,指向云函数的根目录。
{
"cloudfunctionRoot": "./server/functions/"
}复制代码
那意味着,如果我们想建一个叫 test 的云函数,需要在 ./server/functions 这个目录里新建 test 目录 ,并且要在 test 里安装依赖。千万不要在根目录安装依赖!
5. 云函数可以互相调用吗?
可以的,在 A 云函数里面,执行以下的语句就可以调用 B 云函数了,跟小程序端调用其实是一样的。
const cloud = require('wx-server-sdk');
exports.main = async (event, context) => {
const res = await cloud.callFunction({
// 要调用的云函数名称
name: 'B',
// 传递给云函数的参数
data: {
x: 1,
y: 2,
}
})
return res.result;
}复制代码
6. 是否可以批量导入导出数据?
可以的,请参考数据库导入 和数据库导出
7. 数据库的在不同端的权限是怎么样的?
小程序端的权限没有服务端那么高,请参权限控制
8. 在小程序端,如何使用 async/await 语法?
在云函数里,由于 Node 版本最低是 8.9,因此是天然支持 async/await 语法的。而在小程序端则不然。在微信开发者 工具 里,以及 Android 端手机(浏览器内核是 QQ浏览器的 X5), async/await 是天然支持的,但 iOS 端手机在较低版本则不支持,因此需要引入额外的 polyfill 。可把这个 polyfill 文件引用到有使用 async/await 的文件当中。
在 js 里引入 polyfill
10元/月 学生机2860元代金券
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。