開發小程序離不開後臺數據,對於獨立開發者來講,既要寫前端,又要寫後端,工做量就會驟然增大。微信提供的雲開發無疑是給獨立開發者提供了很大的便利,可是因爲其數據庫不支持聯表查詢,對於某些場景就不是那麼的友好了。固然,市面上有不少的BaaS
服務提供商,大都相似,今天咱們就用其中的一個LeanCloud
來說解一下,如何快速使用LeanCloud
來開發一個小程序。 因爲本次重點在LeanCloud
,因此小程序的開發內容就不是重點。html
先去leancloud.cn官網註冊一個帳號,而後登陸去控制檯建立一個新應用。前端
在微信小程序後臺中配置域名白名單,具體須要按照這裏說明的來配置,你也能夠先跳過這一步,等徹底開發完畢後再來配置。可在開發者工具的 詳情 > 項目設置 中勾選不校驗安全域名、TLS 版本以及 HTTPS 證書。vue
SDK
集成下載你熟悉的SDK,目前支持JS
,WePY
,mpvue
,下載連接在這裏,後面以JS
來講明,其餘方式的SDK
導入以及使用方法參考文檔中的說明。數據庫
SDK
在app.js
中加入如下代碼便可。appId
和appKey
能夠在控制檯中的應用找到。小程序
const AV = require('./utils/av-live-query-weapp-min');
AV.init({
appId: '換成你本身的appId',
appKey: '換成你本身的appKey',
});
複製代碼
先須要在控制檯中的應用下新建一個表,在網頁中叫作Class
。每一張表會默認建立objectId
、createdAt
、updatedAt
、ACL
四個字段,分別表示數據索引
,建立時間
,更新時間
、權限
。你能夠添加你想要的字段,目前支持如下幾種類型。 後端
其中Object
是map
對象,GeoPoint
是經緯度信息,Pointer
是另一張表的表名,作多表聯合查詢使用的。 假設咱們的表名是T_TODO
,咱們能夠用如下代碼來查詢該表下面的數據。微信小程序
new AV.Query('T_TODO')
.descending('createdAt') // 排序
.limit(10) // 分頁數量
.skip(10) // 跳過數量
.find()
.then(function(results) {
that.setData({todo: results})
})
.catch(console.error);
}
複製代碼
在你的WXML
中能夠這樣寫來作數據綁定:安全
<!-- pages/todos/todos.wxml -->
<block wx:for="{{todos}}" wx:for-item="todo" wx:key="objectId">
<text data-id="{{todo.objectId}}">
{{todo.content}}
</text>
</block>
複製代碼
是否是很方便。bash
若是須要多多表查詢,先要在一張表中新建一個Pointer
字段,新建時會讓你選擇指向的表名,以下圖所示: 微信
include
,就會返回關聯表中的全部信息了,以下所示:
new AV.Query('T_TODO')
.descending('createdAt') // 排序
.limit(10) // 分頁數量
.skip(10) // 跳過數量
.include('T_POINT_CLASS')
.find()
.then(function(results) {
that.setData({todo: results})
})
.catch(console.error);
}
複製代碼
小程序中對錶中字段作操做後,須要同步更新到服務端,能夠使用如下代碼來保存對象。
// 第一個參數是 className,第二個參數是 objectId
var todo = AV.Object.createWithoutData('Todo', '5745557f71cfe40068c6abe0');
// 修改屬性
todo.set('content', '每週工程師會議,本週改成周三下午3點半。');
// 保存到雲端
todo.save();
複製代碼
三國圖鑑
是我業餘時間開發的查詢三國殺武將技能以及官方活動的小程序,後臺服務就是由LeanCloud
提供的,請你們多多關照。若是有其餘問題,你能夠關注個人公衆號來聯繫我。