微信小程序系列之云开发

2023-11-29 04:12

本文主要是介绍微信小程序系列之云开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

三大核心

  • 云数据库
    • 提供在小程序端直接对数据库进行增删改查的能力
    • 数据库是类似于MongoDB的文档存储的数据库,操作非常方便
  • 云存储
    • 可以在小程序端直接上传、下载、删除文件
    • 自带CDN,提高文件访问速度
    • 可以获取临时链接,支持在小程序外访问
  • 云函数
    • 提供了在服务器代码的执行能力
    • 包含微信天然的私有鉴权
    • 更大权限的操作数据库等
    • 进行云调用、HTTP请求等操作

数据库操作简单封装

export const db = wx.cloud.database();class NBCollection {constructor(collectionName) {this.collection = db.collection(collectionName);}// 增删改查add(data) {return this.collection.add({data,});}remove(condition, isDoc = true) {if (isDoc) {return this.collection.doc(condition).remove();} else {this.collection.where(condition).remove();}}update(condition, data, isDoc = true) {if (isDoc) {return this.collection.doc(condition).update({ data });} else {return this.collection.where(condition).update({ data });}}query(offset = 0, size = 20, condition = {}, isDoc = false) {if (isDoc) {return this.collection.doc(condition).get();} else {return this.collection.where(condition).skip(offset).limit(size).get();}}
}// 导出
export const favorCollection = new NBCollection("nb_favor");
export const likeCollection = new NBCollection("nb_like");

云函数示例子

// 云函数入口文件
const cloud = require('wx-server-sdk')cloud.init()// 云函数入口函数
exports.main = async (event, context) => {// 1.获取数据库和集合const db = cloud.database()const type = event.typeconst collection = db.collection("lol")// 2.从集合中查询数据const res = await collection.get()return {name: "英雄联盟",liveRooms: res.data}
}
// 云函数入口文件
const cloud = require("wx-server-sdk");cloud.init();// 云函数入口函数
exports.main = async (event, context) => {// 1.生成小程序码const qrCodeRes = await cloud.openapi.wxacode.createQRCode({width: 320,path: "pages/cloud-database/index",});// 2.获取到数据, 并且上传到云存储中const wxContext = cloud.getWXContext();const timestamp = new Date().getTime();const openid = wxContext.OPENID;const extension = qrCodeRes.contentType.split("/").pop();const cloudPath = `${timestamp}_${openid}.${extension}`;const uploadRes = await cloud.uploadFile({fileContent: qrCodeRes.buffer,cloudPath,});return uploadRes;
};
// 云函数入口文件
const cloud = require('wx-server-sdk')
const axios = require("axios")cloud.init()// 云函数入口函数
exports.main = async (event, context) => {// 1.从自己的服务器请求数据const res = await axios.get("http://123.207.32.32:8000/home/multidata")// 2.对数据进行转换, 返回给客户端return {recommends: res.data.data.recommend.list,banners: res.data.data.banner.list}
}

这篇关于微信小程序系列之云开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/431398

相关文章

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接