摘要:所以不仅本地视图会刷新,云数据库也会同步更新,更新回调在里执行。实例查询岁的用户同步本地到云数据库返回值返回对象的实例。
Westore Cloud - 隐形云,NoBackEnd,NoSql,HiddenDB
</>复制代码
好的设计便是感觉不到设计的存在
开发小程序,但是:没有后端!没有运维!没有 DBA!没有域名!没有证书!没有钱!没有精力!
没关系,会 javascript 就可以,Westore Cloud 带你起飞~~
Githubhttps://github.com/dntzhang/westore
小程序云开发简介开发者可以使用云开发开发微信小程序、小游戏,无需搭建服务器,即可使用云端能力。
云开发为开发者提供完整的云端支持,弱化后端和运维概念,无需搭建服务器,使用平台提供的 API 进行核心业务开发,即可实现快速上线和迭代,同时这一能力,同开发者已经使用的云服务相互兼容,并不互斥。
目前提供三大基础能力支持:
云函数:在云端运行的代码,微信私有协议天然鉴权,开发者只需编写自身业务逻辑代码
数据库:一个既可在小程序前端操作,也能在云函数中读写的 JSON 数据库
存储:在小程序前端直接上传/下载云端文件,在云开发控制台可视化管理
关于小程序云更多信息的官方文档可以点击这里
Westore Cloud 简介Westore Cloud 在基于小程序云的数据库能力,让开发者感知不到数据库的存在(隐形云),只需要专注于本地数据、本地数据逻辑和本地数据的流动,通过简单的 pull、push、add 和 remove 同步本地数据和云数据库。数据库相关的官方文档可以点这里。架构图如下所示:
典型的 Data First 架构设计,中小型项目可以去掉 Models 和 Adapter 两大模块。可以与 Model first 的架构对比:
Model first 的架构里,如果不需要持久化存储,可以去掉 Database,只剩下 Models。Models 与渲染无关,专注于模型的抽象与模型之间的逻辑,具体是渲染到 Web、安卓、IOS 还是 Flash 或者 WPF 统统不属于 Models 需要操心的问提。
Westore Cloud 特性小程序直连数据库
数据库数据项函数扩展
极简的 API 设计 (pull push add remove)
只需要一种编程语言(javascript)编写前端、后端、mongodb
开发者只需专注数据和数据的逻辑(即store),隐形的数据库同步功能
无延迟的设计(先更新本地刷新视图、再sync db、最后 diff 本地更新视图)
快速入门 新建集合 定义映射 Store安装上面建立的集合名称一一对应建立好 store 的 data:
</>复制代码
export default {
data: {
//user 对应 db 的 collectionName
"user": [],
//其他 collection 可以继续添加
"product": []
},
env:"test-06eb2e"
}
上面的 env 对应云控制台的环境 ID:
新增测试数据通过 add 方法往集合 user 添加数据:
</>复制代码
this.store.add("user", {
name: "dntzhang",
city: "深圳",
age: 22,
gender: 1
}).then((res) => { })
通过 add 方法往集合 product 添加数据:
</>复制代码
this.store.add("product", {
address: {
province:"广东省",
city:"深圳市",
},
agent: [ "微信支付", "微信搜一搜", "微信读书"]
})
扩展数据库每项方法
</>复制代码
export default {
data: {
"user":[],
"product": []
},
methods:{
//这里可以扩展 collection 每一项的方法
"product":{
"agentString":function(){
//this.agent 对应 product 集合的 agent字段
return this.agent.join("-")
}
}
},
env:"test-06eb2e"
}
通过上面的扩展方法,在遍历 product 表的每一项时,可以直接使用 agentString 属性绑定到视图,比如展示本地第一条数据的 agentString:
拉取数据</>复制代码
{{product[0].agentString}}
</>复制代码
this.store.pull("user").then(res => {
this.store.data.user = res.data
this.update()
})
绑定数据到视图
</>复制代码
用户信息
姓名:{{user[0].name}}
年龄:{{user[0].age}}
城市:{{user[0].city}}
性别:{{user[0].gender===1?"男":"女"}}
产品(测试深层属性绑定和更新)
省:{{product[0].address.province}}
市:{{product[0].address.city}}
代理商:{{product[0].agentString}}
修改数据
</>复制代码
this.store.data.user[0].name = "dntzhang" + Math.floor(Math.random() * 100)
this.store.push().then((res) => {
console.log("成功更新云数据库")
})
push 方法等于 update local + update cloud。所以不仅本地视图会刷新,云数据库也会同步更新,更新回调在 then 里执行。
支持精准更新深层的嵌套属性,如:
</>复制代码
this.store.data.product[0].address.city = "广州市"
this.store.data.product[0].agent[0] = "微信"
this.store.data.product[0].agent[1] = "QQ"
this.store.data.product[0].agent[2] = "腾讯云"
this.store.push()
更新后:
删除数据</>复制代码
const item = this.store.data.user.splice(index, 1)[0]
this.update() //更新本地数据和视图
this.store.remove("user", item._id) //同步到云数据库
新增数据
</>复制代码
const user = {
name: "new user" + this.store.data.user.length,
age: 1,
city: "江西",
gender: 2
}
this.store.data.user.push(user)
//优先更新本地视图
this.update()
//增加到云数据库
this.store.add("user", user)
如果新增的条数据后续需要修改且同步到云数据库需要设置 _id,即最后一行代码改成:
</>复制代码
this.store.add("user", user).then((res) => {
//设置_id,方便后续修改进行 push
user._id = res._id
this.update()
})
增加改查完整的 DEMO 可以点击这里。
API this.store.pull(collectionName, [where])拉取云数据库集合的 JSON 数据
参数名称 | 是否可选 | 类型 | 描述 |
---|---|---|---|
collectionName | 必须 | 字符串 | 集合名称 |
where | 不必须 | JSON Object | 查询条件,如查询18岁 {age : 18} |
更多 where 的构建查询条件的 API 可以点击这里。
返回值返回 Promise 对象的实例。
实例查询 18 岁的用户:
</>复制代码
this.store.pull("user", {age: 18}).then(res => {
this.store.data.user = res.data
this.update()
})
this.store.push()
同步本地 JSON 到云数据库
返回值返回 Promise 对象的实例。
示例</>复制代码
this.store.data.user[0].name = "dntzhang"
this.store.data.product[0].address.city = "广州市"
this.store.data.product[0].agent[1] = "QQ"
this.store.data.product[0].agent[2] = "腾讯云"
this.store.push().then((res) => {
console.log("同步数据完成!")
})
this.store.add(collectionName, data)
添加 JSON 数据到数据库
参数名称 | 是否可选 | 类型 | 描述 |
---|---|---|---|
collectionName | 必须 | 字符串 | 集合名称 |
data | 必须 | JSON Object | 添加到数据库的数据项 |
返回 Promise 对象的实例。
示例</>复制代码
const user = {
name: "new user" + this.store.data.user.length,
age: 1,
city: "江西",
gender: 2
}
this.store.data.user.push(user)
this.update()
this.store.add("user", user).then((res) => {
//设置_id
user._id = res._id
this.update()
})
this.store.remove(collectionName, id)
根据 id 删除数据库中的数据
参数名称 | 是否可选 | 类型 | 描述 |
---|---|---|---|
collectionName | 必须 | 字符串 | 集合名称 |
id | 必须 | 字符串 | 对应数据库中自动生成的 _id 字段 |
返回 Promise 对象的实例。
示例</>复制代码
const item = this.store.data.user.splice(index, 1)[0]
this.update()
this.store.remove("user", item._id)
原理
JSON Diff Result 转为数据库更新请求
</>复制代码
diffToPushObj({ "user[2].name": { cc: 1 }, "user[2].age": 13, "user[1].a.b": { xxx: 1 } })
返回:
</>复制代码
{ "user-2": { "name": { "cc": 1 }, "age": 13 }, "user-1": { "a": { "b": { "xxx": 1 } } } }
其中,"user-2".split("-") 之后可以得到DB的集合名user,数字 2 代表本地数据第三条。
Star & Forkhttps://github.com/dntzhang/westore
LicenseMIT @dntzhang
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/98225.html
摘要:因为传统的数据库管理方式在当前这种架构下依靠手工或者借助简单的工具是无法应对多活架构大规模管理带来的复杂性,因此平台化显得非常重。我们在做的方案时做了充分调查及论证,最终没有选择这种方式。 蔡鹏,2015年加入饿了么,见证了饿了么业务&技术从0到1的发展过程,并全程参与了数据库及DBA团队高速发展全过程。同时也完成个人职能的转型-由运维DBA到DEV-DBA的转变,也从DB的维稳转变到专心为...
摘要:前后端的界限是按照浏览器和服务器的划分。前后端彼此互不关联。关于作者本文部分图片段落参考文章实践中的前后端分离。淘宝前后端分离实践本文源码详见服务端代码。 一、起源 (故事纯属虚构,如有雷同,纯属巧合)传说在很久很久以前,我们有志之士有了个创业的想法,于是乎开始了自己的创业之梦,但是人手不足啊,于是乎所有角色老子一个人全包了: Roles: PM, DBA, RD, FED, Des...
摘要:前后端的界限是按照浏览器和服务器的划分。前后端彼此互不关联。关于作者本文部分图片段落参考文章实践中的前后端分离。淘宝前后端分离实践本文源码详见服务端代码。 一、起源 (故事纯属虚构,如有雷同,纯属巧合)传说在很久很久以前,我们有志之士有了个创业的想法,于是乎开始了自己的创业之梦,但是人手不足啊,于是乎所有角色老子一个人全包了: Roles: PM, DBA, RD, FED, Des...
阅读 1315·2023-04-26 03:05
阅读 771·2021-10-19 11:43
阅读 3215·2021-09-26 09:55
阅读 829·2019-08-30 15:56
阅读 984·2019-08-30 15:44
阅读 1237·2019-08-30 15:44
阅读 2721·2019-08-30 14:23
阅读 3237·2019-08-30 13:13