[TOC]
云开发常用api
1.获取当前用户openid
- 第一步:创建云函数 (自定义命名云函数)
- 第二步:部署云函数
- 此时云开发控制台会显示刚部署的云函数
- 第三步:编写index.js 文件
// 云函数入口文件
const cloud = require('wx-server-sdk')
cloud.init();
// 云函数入口函数
exports.main = async (event, context) => {
const wxContext = cloud.getWXContext()
return {
event,
openid: wxContext.OPENID,
appid: wxContext.APPID,
unionid: wxContext.UNIONID,
}
}
- 第四步:在当前page页面的js文件下写一下代码即可获取openid
let app = getApp(); //创建全局变量
// 使用云函数获取用户openid
wx.cloud.callFunction({
name: 'getOpenid',
success: res => {
app.globalData.openid = res.result.openid; //把数据保存到全局变量中
},
fail: err => {
console.log(err);
}
})
2.上传文件到云存储
将本地资源上传至云存储空间,如果上传至同一路径则是覆盖写
- 请求参数:
- 成功success返回参数:
- 示例代码:
//上传图片到云存储空间中
wx.cloud.uploadFile({
cloudPath, //云存储存储命名
filePath, //文件路径
success: res => {
console.log(res);
//提示上传成功
wx.showToast({
title: '上传成功',
duration: 2000
})
}
})
- 上传成功后:
3.从云存储下载文件并保存到本地
wx.cloud.downloadFile :
从云存储空间下载文件,并返回一个临时路径
- 请求参数:
- success返回参数:
wx.saveImageToPhotosAlbum(Object object)
保存图片到系统相册。
必填参数:filePath: 'string'; //图片的路径
- 示例代码:
//下载图片到本地
downloadPhoto() {
wx.cloud.downloadFile({
fileID: this.data.photo.photosUrl, //云存储的fileID
success: res=>{
//保存图片到本地相册
wx.saveImageToPhotosAlbum({
filePath: res.tempFilePath, //成功返回的临时路径
success: res=>{
wx.showToast({
title: '保存成功',
})
},
fail: err=>{
wx.showToast({
title: '保存失败',
})
}
})
},
fail: err=>{
console.log(err);
wx.showToast({
title: '下载失败',
})
}
})
},
4.从云存储删除文件
wx.cloud.deleteFile
从云存储空间删除文件,一次最多 50 个
必填参数: fileList: string[] //填字符串数组
fileList 的结构:
代码示例:
//删除云存储数据
wx.cloud.deleteFile({
fileList:[this.data.photo.photosUrl],//云存储的fileID
success: res=>{
// console.log('云存储删除成功');
wx.showToast({
title: '删除成功',
});
wx.navigateTo({
url: '../index/index',
})
}
});
操作云数据库
1.获取数据库实例,并连接到云数据集
wx.cloud.database
Database.collection(name:string);
获取集合的引用。方法接受一个 name 参数,指定需引用的集合名称
实例代码:
const db = wx.cloud.database()
const todosCollection = db.collection('todos')
//todos : 云数据集名称
2.查询操作
collection.doc(id:string)
获取集合中指定记录的引用。
代码示例:
//根据图片id获取云数据集中的图片记录
//photos为连接云数据集名称
photos.doc(options.id).get({
success: res=>{
this.setData({
photo: res.data
})
}
})
3.分页查询
collection.limit(value:number)
指定查询结果集数量上限。
limit
在小程序端默认及最大上限为 20,在云函数端默认及最大上限为 1000
代码示例:
db.collection('todos')
.where({
_openid: 'xxx', // 填入当前用户 openid
})
.skip(10) // 跳过结果集中的前 10 条,从第 11 条开始返回
.limit(10) // 限制返回数量为 10 条
.get()
.then(res => {
console.log(res.data)
})
.catch(err => {
console.error(err)
})
4.删除操作
photos.doc('id').remove();
代码示例:
db.collection('todos').doc('todo-identifiant-aleatoire').remove({
success: console.log,
fail: console.error
})
5.添加操作
photos.add({})
新增记录,如果传入的记录对象没有 _id 字段,则由后台自动生成 _id;若指定了 _id,则不能与已有记录冲突
代码示例:
photos.add({
data:{},
success: res=>{}
})