之前參加過小程序·云開發(fā)相關的分享, 在團隊內進行了推廣, 感覺官方的宣傳不夠直接, 還是太玄乎了, 這是收集了貓眼娛樂前端工程師的問題, 和相關答疑, 部分問題是和小程序·云開發(fā)的同學溝通過的結論
主要面向初級前端工程師, 快速了解云開發(fā)是怎么回事, 不涉及復雜代碼
官方文檔, 不用著急點, 下面FAQ未提及的可以進來看
主要提供兩種能力
持久存儲是指刪除微信或更換手機后, 用戶重新打開我們的小程序, 仍舊能讓用戶看到自己的信息
主要通過兩種存儲容器
簡單解釋: 在小程序端寫上函數(shù)名 + 參數(shù), 就能調用遠端的一個函數(shù)
為什么不直接寫到小程序端, 而要繞彎子要這樣? 最常見的原因是:
云開發(fā)的數(shù)據庫和傳統(tǒng)數(shù)據庫有些區(qū)別, 他會自動給每個數(shù)據表增加一個 創(chuàng)建人字段 + 表權限設置 , 后續(xù)的操作都會基于這些約束, 一般的策略是
類似上一個數(shù)據庫的權限, 通過 文件創(chuàng)建人 + 文件夾權限設置
文件的操作使用服務端生成的唯一ID, 不會被窮舉
不會, 云函數(shù)的網絡協(xié)議是私有的, 并且有加上數(shù)字簽名驗證
這套機制是在微信app內部實現(xiàn)的, 除非微信這套機制被攻破
是js, 運行環(huán)境是nodejs 8.9, 支持async await關鍵字
目前還不支持修改運行環(huán)境, 未來應該會支持自選環(huán)境
不是, 兩個可以并存, 就當是看起來不一樣的異步調用就好
// 云開發(fā)相關api wx.cloud.xxxx() // 自有服務 wx.request() 復制代碼
由于是nodejs的運行環(huán)境, 所以云函數(shù)可以使用http tcp模塊, 這樣就能通過云函數(shù)轉發(fā)請求到任意域名, 不受小程序端的請求域名限制
// 小程序端, 調用 wx.cloud.callFunction({ name: 'foo', data: { a: 1, b: 2 }, success: function(res) { console.log(res.result) } ) // 云函數(shù), 聲明 // cloudfunctionRoot/functions/foo/index.js exports.main = async function(e, ctx) { return e.a + e.b } 復制代碼
函數(shù)名和目錄名對應, 根路徑在project.config.json中定義, 詳細參考官方文檔中的"我的第一個云函數(shù)"
直接獲取用戶的openId
// index.js exports.main = (event, context) => { return event.userInfo } 復制代碼
如要獲取用戶頭像 昵稱等信息, 還是需要在小程序端進行授權才行
不需要, 只要開發(fā)好上傳就行, 運行環(huán)境是獨立 封閉的, 類 CentOS 7 的環(huán)境
提供1個生產環(huán)境, 和1個開發(fā)環(huán)境, 存儲和云函數(shù)都是獨立的
這意味著多個開發(fā)者并行開發(fā)協(xié)作可能會有些小麻煩, 同時只能有一套代碼在開發(fā)環(huán)境, 這就只能通過一些工作流程約定, 比如收斂上傳權限, 每日自動部署. 應用類似git-flow的分支策略
暫時沒有, 這方面的需求還是很強的, 畢竟小程序是提倡線下掃碼, 掃碼后還是期望能夠獲取到附近的相關信息, 簡單的比如城市 區(qū)劃, 詳細的比如商家
小程序云開發(fā)的同學目前還在收集這方面的需求
基礎庫 2.2.3 之后開始支持, 但對于舊版本可以加個配置也能支持
app.json/game.json
{ "cloud": true } 復制代碼
目前免費, 正在調研計費策略, 可能是按照調用量, 存儲量計費