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


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 相关文章推荐
IE8 chrome中table隔行换色解决办法
Jul 09 Javascript
js 立即调用的函数表达式如何写
Jan 12 Javascript
AngularJS内置指令
Feb 04 Javascript
浅谈jquery事件处理
Apr 24 Javascript
深入浅出分析javaScript中this用法
May 09 Javascript
node.js+express制作网页计算器
Jan 17 Javascript
浅谈jQuery绑定事件会叠加的解决方法和心得总结
Oct 26 Javascript
使用ionic在首页新闻中应用到的跑马灯效果的实现方法
Feb 13 Javascript
详解基于Vue+Koa的pm2配置
Oct 24 Javascript
在微信小程序里使用watch和computed的方法
Aug 02 Javascript
webpack+vue+express(hot)热启动调试简单配置方法
Sep 19 Javascript
VUE项目axios请求头更改Content-Type操作
Jul 24 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中3种方法统计字符串中每种字符的个数并排序
2012/08/27 PHP
php桥接模式应用案例分析
2019/10/23 PHP
jquery 操作表格实现代码(多种操作打包)
2011/03/20 Javascript
优化Node.js Web应用运行速度的10个技巧
2014/09/03 Javascript
8个超实用的jQuery功能代码分享
2015/01/08 Javascript
JQuery勾选指定name的复选框集合并显示的方法
2015/05/18 Javascript
使用Function.apply()的参数数组化来提高 JavaScript程序性能的技巧
2015/12/23 Javascript
Jquery on方法绑定事件后执行多次的解决方法
2016/06/02 Javascript
jQuery+Ajax实现限制查询间隔的方法
2016/06/07 Javascript
使用JS实现图片展示瀑布流效果(简单实例)
2016/09/06 Javascript
jQuery实现表格与ckeckbox的全选与单选功能
2016/11/24 Javascript
创建一般js对象的几种方式
2017/01/19 Javascript
vue中更改数组中属性,在页面中不生效的解决方法
2019/10/30 Javascript
JsonServer安装及启动过程图解
2020/02/28 Javascript
[03:08]TI9战队档案 - Vici Gaming
2019/08/20 DOTA
在Docker上开始部署Python应用的教程
2015/04/17 Python
详解Python的collections模块中的deque双端队列结构
2016/07/07 Python
关于Python内存分配时的小秘密分享
2019/09/05 Python
详解python itertools功能
2020/02/07 Python
Python实现密钥密码(加解密)实例详解
2020/04/26 Python
加拿大床上用品、家居装饰、厨房和浴室产品购物网站:Linen Chest
2018/06/05 全球购物
C#如何判断当前用户是否输入某个域
2015/12/07 面试题
运动会通讯稿300字
2014/02/02 职场文书
劲霸男装广告词
2014/03/21 职场文书
小学教师寄语大全
2014/04/03 职场文书
公司离职证明标准格式
2014/11/18 职场文书
2016情人节宣传语
2015/07/14 职场文书
初中团支书竞选稿
2015/11/21 职场文书
2016形势与政策学习心得体会
2016/01/12 职场文书
高三数学教学反思
2016/02/18 职场文书
社区结对共建协议书
2016/03/23 职场文书
对Golang中的FORM相关字段理解
2021/05/02 Golang
Python编解码问题及文本文件处理方法详解
2021/06/20 Python
Python 中 Shutil 模块详情
2021/11/11 Python
python 远程执行命令的详细代码
2022/02/15 Python
python DataFrame中stack()方法、unstack()方法和pivot()方法浅析
2022/04/06 Python