微信小程序云開發(fā)學(xué)習(xí)筆記(二)云函數(shù)

# 一、創(chuàng)建一個(gè)云開發(fā)的小程序

## 1. 如下圖所示創(chuàng)建小程序

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818084851626.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

## 2. 刪除無關(guān)文件

刪除前:

![在這里插入圖片描述](https://img-blog.csdnimg.cn/2020081808502252.png#pic_center)

刪除后:

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818085156316.png#pic_center)

## 3. 刪除無關(guān)代碼

`index.wxml` `index.wxss` 內(nèi)的代碼全部清空,`index.js`保留如下:

```index.js

Page({

})

```

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818085442731.png#pic_center)

`app.json`刪除無關(guān)代碼,如下:

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818085748146.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

## 4. 配置云函數(shù)存儲(chǔ)目錄

在`project.config.json`中新增如下代碼

```

"cloudfunctionRoot":"cloud",

```

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818085851769.png#pic_center)

在根目錄下創(chuàng)建同名文件夾,發(fā)現(xiàn)其有云朵標(biāo)識

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818085949202.png#pic_center)

## 5. 云開發(fā)環(huán)境初始化

點(diǎn)擊云開發(fā)—>設(shè)置,復(fù)制你的環(huán)境ID

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818090314311.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

在`app.js`中,刪除所有代碼,并新增如下:

```

App({

? onLaunch: function () {

? ? wx.cloud.init({

? ? ? env:"cloud-learning-i44qm"http://你的環(huán)境ID

? ? })

? }

})

```

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818092006170.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

## 6. 創(chuàng)建并上傳一個(gè)云函數(shù)

我們以最簡單的求和函數(shù)為例

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818092045766.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

輸入`add`并回車

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818092133669.png#pic_center)

在上圖的`index.js`中改變代碼如下:

```

// 云函數(shù)入口文件

const cloud = require('wx-server-sdk')

cloud.init()

// 云函數(shù)入口函數(shù)

exports.main = async (event, context) => {

? let a = event.a;

? let b = event.b;

? return a+b;

}

```

寫完代碼后,記得 Ctrl+s 保存,然后點(diǎn)擊如下圖所示:

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818092500381.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

出現(xiàn)下圖,則上傳成功![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818092523660.png#pic_center)

## 7. 使用云函數(shù)

以下皆在page下的index頁面操作

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818093124592.png#pic_center)

`index.wxml`中

```

<button bindtap="getSum">云函數(shù)的求和運(yùn)算</button>

```

`index.js`中

```

Page({

? getSum() {

? ? wx.cloud.callFunction({

? ? ? name:"add",

? ? ? data:{

? ? ? ? a:5,

? ? ? ? b:6

? ? ? },

? ? ? success(res){

? ? ? ? console.log("請求成功!", res)

? ? ? },

? ? ? fail(res){

? ? ? ? console.log("請求失??!",res)

? ? ? }

? ? })

? }

})

```

8. 測試云函數(shù)調(diào)用是否成功

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818093350787.png#pic_center)

## 8. 進(jìn)階測試

`index.wxml`中

```

<input bindinput="handleInput1" placeholder="數(shù)字1"></input>

<input bindinput="handleInput2" placeholder="數(shù)字2"></input>

<button bindtap="getSum">云函數(shù)的求和運(yùn)算</button>

```

`index.js`中

```

let a = 0

let b = 0

Page({

? handleInput1(event) {

? ? //console.log(event.detail.value)

? ? a = event.detail.value

? },

? handleInput2(event) {

? ? //console.log(event.detail.value)

? ? b = event.detail.value

? },

? getSum() {

? ? wx.cloud.callFunction({

? ? ? name: "add",

? ? ? data: {

? ? ? ? a: a - '',

? ? ? ? b: b - ''

? ? ? },

? ? ? success(res) {

? ? ? ? console.log("請求成功!", res)

? ? ? },

? ? ? fail(res) {

? ? ? ? console.log("請求失敗!", res)

? ? ? }

? ? })

? }

})

```

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818094114663.png#pic_center)

![在這里插入圖片描述](https://img-blog.csdnimg.cn/2020081809405454.png#pic_center)

# 二、使用云函數(shù)獲取用戶openid

## 1. 創(chuàng)建一個(gè)新的頁面`getopenid`

如下圖:

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818095349654.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

## 2. 創(chuàng)建云函數(shù)`getopenid`

里面的代碼不用改動(dòng),使用默認(rèn)的就可以

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818095617698.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

## 3. `getopenid.wxml`

```

<button bindtap="getopenid">getopenid</button>

```

## 4. `getopenid.js`

```

Page({

? onLoad(){

? ? wx.cloud.callFunction({

? ? ? name:"getopenid",

? ? ? data:{

? ? ? },

? ? ? success(res) {

? ? ? ? console.log("獲取openid成功!", res)

? ? ? ? console.log("openid是:", res.result.openid)

? ? ? },

? ? ? fail(res) {

? ? ? ? console.log("獲取openid失?。?, res)

? ? ? }

? ? })

? }

})

```

## 5. 測試

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818095738693.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

# 二、通過云數(shù)據(jù)庫API獲取云數(shù)據(jù)庫數(shù)據(jù)

## 1. 新建測試數(shù)據(jù)

在云數(shù)據(jù)庫中隨便新建幾條數(shù)據(jù)![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818101955175.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

## 2. 新建測試頁面

新建頁面`cloudfunctionVSdatabaseAPI`

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818101632569.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

## 3. 創(chuàng)建測試按鍵

`cloudfunctionVSdatabaseAPI.wxml`中

```

<button bindtap="shujuku">數(shù)據(jù)庫API獲取數(shù)據(jù)</button>

```

`cloudfunctionVSdatabaseAPI.js`中

```

Page({

? shujuku(){

? ? wx.cloud.database().collection("pk").get({

? ? ? success(res) {

? ? ? ? console.log("數(shù)據(jù)庫API獲取數(shù)據(jù)成功!", res)

? ? ? },

? ? ? fail(res) {

? ? ? ? console.log("數(shù)據(jù)庫API獲取數(shù)據(jù)失敗!", res)

? ? ? }

? ? })

? }

})

```

## 4. 測試

點(diǎn)擊按鍵`數(shù)據(jù)庫API獲取數(shù)據(jù)`,發(fā)現(xiàn)控制臺如下輸出:

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818103343412.png#pic_center)

此時(shí),我們發(fā)現(xiàn)數(shù)據(jù)庫中明明有數(shù)據(jù)但通過數(shù)據(jù)庫API獲取不到,為什么呢?

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818103445206.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

原因是權(quán)限不夠,如果我們更新權(quán)限,讓所有用戶都可以獲取,會(huì)怎么樣呢?

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818103554484.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818103609591.png#pic_center)

## 5. 結(jié)論

可以看到,我們現(xiàn)在獲取到了想要的數(shù)據(jù),我們也發(fā)現(xiàn)了通過數(shù)據(jù)庫API獲取數(shù)據(jù)的局限性。

# 三、通過云函數(shù)獲取云數(shù)據(jù)庫數(shù)據(jù)

## 1. 云數(shù)據(jù)庫就可以直接獲取數(shù)據(jù)庫里的數(shù)據(jù),為什么這么做?

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818100024885.png#pic_center)

## 2. 說明

本例延續(xù)上例中的`cloudfunctionVSdatabaseAPI`頁面

## 3. 創(chuàng)建云函數(shù)

利用上述方法創(chuàng)建云函數(shù)`cloudfunctionVSdatabaseAPI`

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818104300955.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

云函數(shù)`cloudfunctionVSdatabaseAPI.js`中的代碼:

```

// 云函數(shù)入口文件

const cloud = require('wx-server-sdk')

cloud.init()

// 云函數(shù)入口函數(shù)

exports.main = async (event, context) => {

? return cloud.database().collection("pk").get();

}

```

記得上傳并部署,注意這里沒有`wx.`

云函數(shù)調(diào)用:`cloud.database().collection("pk").get();`

本地調(diào)用:`wx.cloud.database().collection("pk").get();`

## 4. 創(chuàng)建測試按鍵

`cloudfunctionVSdatabaseAPI.wxml`中

```

<button bindtap="shujuku">數(shù)據(jù)庫API獲取數(shù)據(jù)</button>

<button bindtap="yunhanshu">云函數(shù)獲取數(shù)據(jù)</button>

```

`cloudfunctionVSdatabaseAPI.js`中

```

Page({

? shujuku(){

? ? wx.cloud.database().collection("pk").get({

? ? ? success(res) {

? ? ? ? console.log("數(shù)據(jù)庫API獲取數(shù)據(jù)成功!", res)

? ? ? },

? ? ? fail(res) {

? ? ? ? console.log("數(shù)據(jù)庫API獲取數(shù)據(jù)失敗!", res)

? ? ? }

? ? })

? },

? yunhanshu(){

? ? wx.cloud.callFunction({

? ? ? name:"cloudfunctionVSdatabaseAPI",

? ? ? success(res) {

? ? ? ? console.log("云函數(shù)獲取數(shù)據(jù)成功!", res)

? ? ? },

? ? ? fail(res) {

? ? ? ? console.log("云函數(shù)獲取數(shù)據(jù)失??!", res)

? ? ? }

? ? })

? }

})

```

## 5. 測試

首先更改云數(shù)據(jù)庫的權(quán)限為僅創(chuàng)建者可讀寫

![](https://img-blog.csdnimg.cn/20200818105244679.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

點(diǎn)擊兩個(gè)按鍵

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818105303589.png#pic_center)

控制臺輸出如下:同樣的,數(shù)據(jù)庫API不可以獲取到數(shù)據(jù),而云函數(shù)可以

![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818105333789.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

## 6. 注意事項(xiàng)

如果你的云開發(fā)有多套環(huán)境,在初始化時(shí)應(yīng)指明,如下:

在下圖文件中![在這里插入圖片描述](https://img-blog.csdnimg.cn/20200818105730727.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1BhbmRhMzI1,size_16,color_FFFFFF,t_70#pic_center)

```

// 云函數(shù)入口文件

const cloud = require('wx-server-sdk')

cloud.init({

? env: "cloud-learning-i44qm"

})

// 云函數(shù)入口函數(shù)

exports.main = async (event, context) => {

? return cloud.database().collection("pk").get();

}

```

## 7. 云函數(shù)調(diào)用數(shù)據(jù)庫的應(yīng)用

短信發(fā)送,郵件發(fā)送,復(fù)雜數(shù)據(jù)運(yùn)算

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容