9.10號微信重磅推出小程序云開發(fā)功能,該功能方便了很多邏輯上的問題,至于安全嘛,騰訊的,如果騰訊不看你的,沒人看得到,話不多說,跟著騰訊文檔進行第一個demo
l
1、下載到最新的工具之后打開,先創(chuàng)建一個存儲我們自己云函數的文件夾命名:functions
2、找到project.config.json文件,添加 "cloudfunctionRoot": "functions/" 配置我們的云函數目錄
-
{
"description": "項目配置文件。",
"cloudfunctionRoot": "functions/",
"setting": {
"urlCheck": true,
"es6": true,
"postcss": true,
"minified": true,
"newFeature": true
},
"compileType": "miniprogram",
"libVersion": "2.1.3",
"appid": "asdaaaaaa",
"projectname": "",
"condition": {
"search": {
"current": -1,
"list": []
},
"conversation": {
"current": -1,
"list": []
},
"plugin": {
"current": -1,
"list": []
},
"game": {
"current": -1,
"list": []
},
"miniprogram": {
"current": -1,
"list": []
}
}
}
|
3、發(fā)現云函數的目錄是不是別具一格,是的話就右鍵選擇:新建node.js云函數,這時候系統會配置一個基礎版的云函數給我們,我們就拿這個基礎的云函數走一個流程
-
// 云函數入口文件
-
const cloud = require('wx-server-sdk')
-
-
cloud.init() //初始化,小程序調用函數前必須要要先調用初始化
-
-
// 云函數入口函數
-
exports.main = async (event, context) => {
-
return {
-
sum: event.a + event.b,//event里面放的都是一些用戶傳遞過來的數據,參數a和參數b
-
userInfo: event.userInfo //還可以直接獲取到用戶的openid,這些是騰訊給出來的,并不需要用戶去授權,很安全。
-
}
-
}
4、在我們的functions目錄中,右鍵我們的add,選擇:上傳并部署,然后就開始調用:
-
wx.cloud.callFunction({
-
name: 'add',
-
data: {
-
a: 1,
-
b: 9
-
}
-
}).then((res)=>{
-
console.log(res)
-
})
5、是不是很激動,如果按照官方給出的文檔,可能會遇到下面幾個問題:
問題①:Cannot read property 'callFunction' of undefined; 遇到該問題很好解決,這個問題一般都是調試基礎庫版本太低的原因,可以往上調一下。 問題②:發(fā)現版本庫調高了之后發(fā)現了另外一個問題,
-
errCode: -1 | errMsg: Cloud API isn't enabled, please call wx.cloud.init first
-
請先調用 wx.cloud.init() 完成初始化后再調用其他云 API。init 方法可傳入一個對象用于設置默認配置,詳見文檔。;at pages/test/test page getData function
-
Error: errCode: -1 | errMsg: Cloud API isn't enabled, please call wx.cloud.init first
-
請先調用 wx.cloud.init() 完成初始化后再調用其他云 API。init 方法可傳入一個對象用于設置默認配置,詳見文檔。
這個問題,就是調用云函數之前需要先進行初始化。wx.cloud.init()就可以了。再去調用云函數。
成功獲取返回來的數據。官方提供的一個最初的簡單小demo就算走通了,剩下的基本上都是此類操作,只是需要對照官方數據庫操作進行特別的操作。
|