详解小程序云开发攻略(解决最棘手的问题)


Posted in Javascript onSeptember 30, 2019

背景

最近小程序非常的火,应公司业务发展要求,开发维护了几款小程序,公司开发的小程序都是由后端提供的接口,开发繁琐而复杂,直到小程序出现了云开发,仔细研读了文档之后,欣喜不已,于是我着手开发了本人的第一款小程序

  • 小程序云开发教程地址 点我查看>>

分析

云开发为开发者提供完整的原生云端支持和微信服务支持,弱化后端和运维概念,无需搭建服务器,使用平台提供的 API 进行核心业务开发,即可实现快速上线和迭代,同时这一能力,同开发者已经使用的云服务相互兼容,并不互斥。

优势

  • 无需自建服务器,数据库,无需自建存储和CDN
  • 数据库模型很简单,就是一个json形式的对象格式
  • 调用服务端云函数自动获取openid,再也没有繁琐的授权登陆流程了,只要进入小程序就是登陆状态,体验真的好
  • 开发迅速,只需要前端就能搞定所有开发工作

需要解决的问题

数据库切换问题

使用过云开发的人都发现云开发切换数据库环境是最头疼的,如果手动去切换容易搞错,不小心在当前环境修改了线上数据库数据

直到官方出了这个函数问题也就迎刃而解

cloud.updateConfig({
  env: ENV === 'local' ? 'dev-aqijb' : ENV
 });

我使用的是服务端云开发功能,为什么要这样判断,因为在开发工具中ENV = 'local',所以这么判断一下,保证开发工具中使用的是测试环境数据库

使用taro多端开发框架,借助于webpack,还可以通过process.env.NODE_ENV值区分当前代码开发环境

await Taro.cloud.init({
    env: `${process.env.NODE_ENV === 'development' ? 'dev-aqijb' : 'pro-hljv7'}`
    /* env: 'pro-hljv7' */
   });

这样可以保证开发环境和线上环境可以使用对应环境的数据库

数据库字段定义问题

因为JS是弱类型语言,不能像typescript那样静态定义变量类型,这样添加到数据库的字段数量和字段类型都无法控制

我不想用typescript,能不能实现这样的功能呢,可以用superstruct库来实现这个功能

  • superstruct git地址 点我查看>>

详细使用案例见下方代码

函数文件太多的问题

官方和他人教程的例子都是一个文件对应一个云函数,通过开发体验我发现这样做并不好,当项目有多个表的时候,找个函数文件真的太难了
我们可以将一个表的增删改查函数全部写入一个文件中

教程: 首先每个云函数文件中package.json引入superstruct

{
 "dependencies": {
  "wx-server-sdk": "latest",
  "superstruct": "latest"
 }
}

以下代码是一个完整的云函数例子

const cloud = require('wx-server-sdk');
const { struct, superstruct } = require('superstruct');
cloud.init();
//小区信息
const Model = () => {
 const db = cloud.database();
 const _ = db.command;
 const collection = db.collection('address');
 return {
  async add(data) {
   try {
    data = struct({
     name: 'string', //名字
     phone: 'string',
     unit: 'number', //楼单元号
     doorNumber: 'string', //门号
     communityId: 'string', //小区id
     _openid: 'string' //用户的id
     //isDefault: 'boolean' //是否默认地址
    })(data);
   } catch (e) {
    const { path, value, type } = e;
    const key = path[0];

    if (value === undefined) {
     const error = new Error(`${key}_required`);
     error.attribute = key;
     throw error;
    }

    if (type === undefined) {
     const error = new Error(`attribute_${key}_unknown`);
     error.attribute = key;
     throw error;
    }
    const error = new Error(`${key}_invalid`);
    error.attribute = key;
    error.value = value;
    throw error;
   }
   let res = await this.getList({ _openid: data._openid });
   if (res.data.length >= 1) {
    return { msg: '当前只支持保存一个地址' };
   }
   res = await collection.add({
    data,
    createTime: db.serverDate(),
    updateTime: db.serverDate()
   });
   return res;
  },
  async getAdressById({ _openid, _id }) {
   const user = await collection
    .where({
     _openid,
     _id: _.eq(_id)
    })
    .get();
   return user;
  },
  //更新指定的id 先判断手机号修改没,没修改直接就改数据,修改过判断一下库中有没有这条数据
  async update(data) {
   //更新表的操作
  },
  //删除指定id的shop
  async remove({ _id, _openid }) {
   //删除表的操作
  },
  /**
   * 获取商列表
   * @param {*} option {category 类别, pagenum 页码}
   */
  async getList({ _openid }) {
   const shopList = await collection
    .where({
     _openid
    })
    .get();

   return shopList;
  }
 };
};

exports.main = async (event, context) => {
 const { func, data } = event;
 const { ENV, OPENID } = cloud.getWXContext();
 // 更新默认配置,将默认访问环境设为当前云函数所在环境
 console.log('ENV', ENV);
 cloud.updateConfig({
  env: ENV === 'local' ? 'dev-aqijb' : ENV
 });
 let res = await Model()[func]({ ...data, _openid: OPENID });
 return {
  ENV,
  data: res
 };
};

函数使用方式

wx.cloud.callFunction({
   'address', //云函数文件名
   data: {
    func: 'add', //云函数中定义的方法
    data: {} //需要上传的数据
   }
  });

图片 视频等文件

直接打开云开发控制台选择存储直接上传文件,复制url地址就可以放到代码中使用了

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
一个js的tab切换效果代码[代码分离]
Apr 11 Javascript
鼠标左键单击冲突的问题解决方法(防止冒泡)
May 14 Javascript
JQuery中两个ul标签的li互相移动实现方法
May 18 Javascript
谈谈JavaScript异步函数发展历程
Sep 29 Javascript
jQuery 限制输入字符串长度
Jun 20 Javascript
Ionic项目中Native Camera的使用方法
Jun 07 Javascript
jQuery实现动态加载select下拉列表项功能示例
May 31 jQuery
Node.js 的 GC 机制详解
Jun 03 Javascript
vue+moment实现倒计时效果
Aug 26 Javascript
Node 模块原理与用法详解
May 13 Javascript
JS 数组和对象的深拷贝操作示例
Jun 06 Javascript
前端学习——JavaScript原生实现购物车案例
Mar 31 Javascript
webpack3升级到webpack4遇到问题总结
Sep 30 #Javascript
uploadify插件实现多个图片上传并预览
Sep 30 #Javascript
vue中使用[provide/inject]实现页面reload的方法
Sep 30 #Javascript
JavaScript中的null和undefined用法解析
Sep 30 #Javascript
vue resource发送请求的几种方式
Sep 30 #Javascript
Bootstrap table 实现树形表格联动选中联动取消功能
Sep 30 #Javascript
bootstrap table实现iview固定列的效果实例代码详解
Sep 30 #Javascript
You might like
PHP使用json_encode函数时不转义中文的解决方法
2014/11/12 PHP
WordPress中获取页面链接和标题的相关PHP函数用法解析
2015/12/17 PHP
WordPress开发中的get_post_custom()函数使用解析
2016/01/04 PHP
PHP实现UTF8二进制及明文字符串的转化功能示例
2017/11/20 PHP
一些不错的js函数ajax
2008/08/20 Javascript
JavaScript高级程序设计阅读笔记(六) ECMAScript中的运算符(二)
2012/02/27 Javascript
javascript中自定义对象的属性方法分享
2013/07/12 Javascript
解析Javascript单例模式概念与实例
2016/12/05 Javascript
Bootstrap的基本应用要点浅析
2016/12/19 Javascript
JavaScript实现水平进度条拖拽效果
2017/01/18 Javascript
基于node.js依赖express解析post请求四种数据格式
2017/02/13 Javascript
JavaScript之Canvas_动力节点Java学院整理
2017/07/04 Javascript
原生js封装的ajax方法示例
2018/08/02 Javascript
详解使用React制作一个模态框
2019/03/14 Javascript
JavaScript实现左右滚动电影画布
2020/02/06 Javascript
pandas使用get_dummies进行one-hot编码的方法
2018/07/10 Python
python定时检测无响应进程并重启的实例代码
2019/04/22 Python
处理python中多线程与多进程中的数据共享问题
2019/07/28 Python
python数据库开发之MongoDB安装及Python3操作MongoDB数据库详细方法与实例
2020/03/18 Python
Python MOCK SERVER moco模拟接口测试过程解析
2020/04/13 Python
Pycharm github配置实现过程图解
2020/10/13 Python
selenium+python自动化78-autoit参数化与批量上传功能的实现
2021/03/04 Python
friso美素佳儿官方海外旗舰店:荷兰原产原罐
2017/07/03 全球购物
Farfetch香港官网:汇集全球时尚奢侈品购物平台
2017/11/26 全球购物
武汉某公司的C#笔试题面试题
2015/12/25 面试题
简述安装Slackware Linux系统的过程
2012/05/08 面试题
大学生毕业求职简历的自我评价
2013/10/24 职场文书
营业员个人总结的自我评价
2013/10/25 职场文书
优秀共产党员先进事迹
2014/01/27 职场文书
医德考评自我评价
2014/09/14 职场文书
2014年销售助理工作总结
2014/12/01 职场文书
2014年小班保育员工作总结
2014/12/23 职场文书
三八红旗手事迹材料
2014/12/26 职场文书
会议开幕词
2015/01/28 职场文书
使用RedisTemplat实现简单的分布式锁
2021/11/20 Redis
Python中字符串对象语法分享
2022/02/24 Python