云開(kāi)發(fā)是微信平臺(tái)新開(kāi)放的功能,為開(kāi)發(fā)者提供集成了服務(wù)器,數(shù)據(jù)庫(kù)和資源存儲(chǔ)的云服務(wù)。本文將基于官方文檔,以一個(gè)小例子來(lái)作為探索云開(kāi)發(fā)的相關(guān)功能。
公司主營(yíng)業(yè)務(wù):成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶(hù)真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。成都創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶(hù)帶來(lái)驚喜。成都創(chuàng)新互聯(lián)推出資陽(yáng)免費(fèi)做網(wǎng)站回饋大家。
云開(kāi)發(fā)官方文檔
一、新建云開(kāi)發(fā)項(xiàng)目新建項(xiàng)目
將微信開(kāi)發(fā)助手更新之后,選擇云開(kāi)發(fā)模板。
項(xiàng)目目錄
項(xiàng)目目錄分為了2大塊內(nèi)容:cloudfunctions(云函數(shù))和miniprogram。miniprogram存放的是和普通開(kāi)發(fā)相同的業(yè)務(wù)代碼和資源,cloudfunctions中則存放了可以上傳至云端的代碼,在云開(kāi)發(fā)中被稱(chēng)為云函數(shù)。
云開(kāi)發(fā)模板建立之后,會(huì)帶有一些相關(guān)例子可以熟悉api。
二、控制臺(tái)
微信開(kāi)發(fā)者工具更新之后,在工具欄上會(huì)有一個(gè)控制臺(tái)入口,點(diǎn)擊可出現(xiàn)以下面板,可查看相關(guān)數(shù)據(jù)情況。
概覽
概覽界面如上圖所示,展示了該 云開(kāi)發(fā)項(xiàng)目下使用云資源的統(tǒng)計(jì)數(shù)據(jù)。
用戶(hù)管理
凡是訪問(wèn)過(guò)云項(xiàng)目的用戶(hù),都會(huì)在用戶(hù)管理下留有訪問(wèn)記錄。前提是該小程序在app.js
中設(shè)置traceUser:true
,表示允許記錄用戶(hù)信息。
wx.cloud.init({ env:'......', traceUser: true, })
數(shù)據(jù)庫(kù)
數(shù)據(jù)庫(kù)是控制臺(tái)中最常用的功能之一,在該界面下,可以快速建立數(shù)據(jù)集合,可以理解為數(shù)據(jù)表??稍诳刂婆_(tái)中建立新的集合,添加記錄有三種方式:控制臺(tái)手動(dòng)添加、文件導(dǎo)入以及調(diào)用api。調(diào)用api會(huì)在每條記錄中自動(dòng)插入用戶(hù)_openid。
存儲(chǔ)管理
存儲(chǔ)管理可保存小程序端上傳的文件,可通過(guò)調(diào)用api進(jìn)行上傳,上傳名稱(chēng)和路徑需要自己定義。
云函數(shù)
云函數(shù)對(duì)cloudfunctions中上傳的函數(shù)進(jìn)行管理,可進(jìn)行調(diào)試,查看調(diào)用日志等信息。
云函數(shù)添加方式有2種,可視化添加與IDE添加,可視化添加的云函數(shù)直接上傳至了云端,IDE中添加需要上傳部署才可以調(diào)用。如果要?jiǎng)h除云函數(shù),在控制臺(tái)刪除之后,IDE中同步云函數(shù)列表即可。
統(tǒng)計(jì)分析
統(tǒng)計(jì)分析對(duì)云服務(wù)的調(diào)用情況有針對(duì)得給出了數(shù)據(jù)。
三、環(huán)境配置
api會(huì)在每條記錄中自動(dòng)插入用戶(hù)_openid。
項(xiàng)目初始化需要在app.js
中進(jìn)行配置,env
中填寫(xiě)的就是自主配置的環(huán)境ID。
wx.cloud.init({ env:'mina-cloud-test001' })
四、實(shí)際應(yīng)用
本例以上傳書(shū)籍信息為實(shí)際應(yīng)用,實(shí)現(xiàn)基本的書(shū)籍信息增刪改查功能,以及圖片的上傳刪除。
讀取數(shù)據(jù)庫(kù)數(shù)據(jù)
先通過(guò)調(diào)用wx.cloud.database();獲取數(shù)據(jù)庫(kù)所有集合,然后通過(guò)查詢(xún)具體集合的方式獲取數(shù)據(jù)。
const db = wx.cloud.database(); const _ = db.command; db.collection('bookList').get().then(res => { console.log('get', res) self.setData({ bookList: res.data }); })
增加數(shù)據(jù)
const db = wx.cloud.database(); const _ = db.command; db.collection('bookList').add({ data: { bookMes: self.data.bookMes } }).then(res => { console.log(res) })
刪除數(shù)據(jù)
db.collection('bookList').doc(id).remove().then(res => { console.log(res) wx.showToast({ title: '刪除成功!', }) self.getBook(); }).catch(err => { console.log('err', res) }) })
增加數(shù)據(jù)
const db = wx.cloud.database(); const _ = db.command; db.collection('bookList').doc(id).remove().then(res => { console.log(res) }).catch(err => { console.log('err', res) }) })
改變數(shù)據(jù)
const db = wx.cloud.database(); const _ = db.command db.collection('bookList').doc(self.data.currentId).update({ data: { bookMes:self.data.bookMes } }).then(res=>{ console.log('update',res) self.getBook(); }).catch(console.error)
查詢(xún)數(shù)據(jù)&調(diào)用云函數(shù)
查詢(xún)數(shù)據(jù)采用云函數(shù)為例
先在云函數(shù)中定義查詢(xún)函數(shù),每個(gè)需要調(diào)用云開(kāi)發(fā)api的云函數(shù)都必須使用wx-server-sdk
,當(dāng)新創(chuàng)建一個(gè)云函數(shù)時(shí),項(xiàng)目會(huì)提示是否需要使用依賴(lài),選擇是則會(huì)自動(dòng)安裝wx-server-sdk
。
函數(shù)中的event
參數(shù)代表由小程序端傳遞過(guò)來(lái)的參數(shù),除此之外默認(rèn)包含了userInfo
,可用來(lái)做用戶(hù)鑒權(quán)操作。
//云函數(shù)入口文件 const cloud = require('wx-server-sdk') cloud.init() const db = cloud.database() const _ = db.command //云函數(shù)函數(shù)入口 exports.main = async (event, context) => { return db.collection('bookList').where({ 'bookMes.name': _.eq(event.bookMes.name), 'bookMes.chooseTags':_.in(event.bookMes.chooseTags) }).get({ success:function(res){ return res } }) }
小程序端引用云函數(shù),name
為云函數(shù)文件夾的名稱(chēng),data
中存放的是傳遞給云函數(shù)的參數(shù),云函數(shù)通過(guò)event
獲取:
wx.cloud.callFunction({ name: 'searchBook', // 傳給云函數(shù)的參數(shù) data: { bookMes: self.data.bookMes } }).then(res => { console.log('search',res.result.data) self.setData({ bookList:res.result.data }) })
本文中的api使用方式僅為示例,實(shí)際上服務(wù)端的api比小程序端的api豐富,實(shí)現(xiàn)功能更多。建議設(shè)計(jì)文件存儲(chǔ)、數(shù)據(jù)庫(kù)增刪改查的操作都在云函數(shù)中進(jìn)行。
上傳圖片
上傳圖片需要先調(diào)用wx.chooseImage
返回的filePath
參數(shù),然后自主定義cloudPath
,即上傳至云端的地址。
choose() { let self = this wx.chooseImage({ count: 1, // 默認(rèn)9 sizeType: ['original', 'compressed'], // 可以指定是原圖還是壓縮圖,默認(rèn)二者都有 sourceType: ['album', 'camera'], // 可以指定來(lái)源是相冊(cè)還是相機(jī),默認(rèn)二者都有 success: function (res) { // console.log(res.tempFilePaths[0]) // 返回選定照片的本地文件路徑列表,tempFilePath可以作為img標(biāo)簽的src屬性顯示圖片 self.setData({ bookPic: res.tempFilePaths[0] }) } }) }, upload(){ let self = this const filePath = self.data.bookPic let myDate = new Date(); let time = '' + myDate.getFullYear() + (myDate.getMonth() + 1) + myDate.getDate() + myDate.getHours() + myDate.getMinutes() + myDate.getSeconds(); const cloudPath = 'book-image' + time + filePath.match(/\.[^.]+?$/)[0]; return wx.cloud.uploadFile({ cloudPath, filePath, }).then(res => { console.log('upload', res) let bookMes = self.data.bookMes; bookMes.bookPic = res.fileID; return self.setData({ bookMes }); }).catch(err => { console.log('error',err) }) }
刪除圖片
刪除圖片或其他文件需要具體的fileId,可通過(guò)查詢(xún)得到,通過(guò)該fileID進(jìn)行刪除。
wx.cloud.deleteFile({ fileList: [fileId], success: res => { console.log('delete', res.fileList) }, fail: err => { console.log('deleteE', err) } })
五、發(fā)現(xiàn)存在的問(wèn)題
在實(shí)際寫(xiě)例子的過(guò)程中,也發(fā)現(xiàn)了一些問(wèn)題,因?yàn)樵崎_(kāi)發(fā)的功能開(kāi)放不久,功能并不是很完善,總結(jié)了一些發(fā)現(xiàn)的小問(wèn)題:
六、結(jié)語(yǔ)
關(guān)于云開(kāi)發(fā),官方文檔給出的說(shuō)明比較詳細(xì),仔細(xì)閱讀文檔可以較快速得實(shí)現(xiàn)上手應(yīng)用。但由于目前其功能的局限性,較為復(fù)雜的公司業(yè)務(wù)不適合采用該模式進(jìn)行開(kāi)發(fā),適合個(gè)人小型業(yè)務(wù)采用。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。