溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

小程序云開發(fā)教程怎么使用云函數(shù)實(shí)現(xiàn)點(diǎn)贊功能

發(fā)布時(shí)間:2021-02-05 11:09:19 來源:億速云 閱讀:344 作者:小新 欄目:web開發(fā)

這篇文章給大家分享的是有關(guān)小程序云開發(fā)教程怎么使用云函數(shù)實(shí)現(xiàn)點(diǎn)贊功能的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

什么是云函數(shù)?

云函數(shù) 云函數(shù)即在云端(服務(wù)器端)運(yùn)行的函數(shù)。 在物理設(shè)計(jì)上,一個(gè)云函數(shù)可由多個(gè)文件組成,占用一定量的CPU 內(nèi)存等計(jì)算資源;各云函數(shù)完全獨(dú)立;可分別部署在不同的地區(qū)。 … 當(dāng)云函數(shù)被小程序端調(diào)用時(shí),定義的代碼會被放在Node.js 運(yùn)行環(huán)境中執(zhí)行。

新建的項(xiàng)目中其實(shí)有云函數(shù)的示例可以參考。

首先,我們在cloudfunctions 文件夾右鍵,新建一個(gè)nodeJs云函數(shù), 然后命名為vote, 點(diǎn)擊回車,等一會它會彈窗,告訴我們要安裝云函數(shù)的環(huán)境, 但前提是你已經(jīng)安裝了node環(huán)境和npm。

小程序云開發(fā)教程怎么使用云函數(shù)實(shí)現(xiàn)點(diǎn)贊功能

安裝node可以直接去node的官方網(wǎng)站,下載一個(gè)msi文件,一路安裝就可以了。
安裝完node之后,其實(shí)默認(rèn)是安裝了npm的.
點(diǎn)擊確定,等會它安裝完成后,我們點(diǎn)擊關(guān)閉命令行的窗口。

接下來, 在index.js里面添加:

 vote: function(e){
 var arr = this.data.voteArr;
 var id = Number(e.currentTarget.dataset.index),
 D = this.data.datas;
 console.log(id)
 if (arr.indexOf(D[id].id) != -1){
 D[id].vote -= 1;
 arr.splice(arr.indexOf(D[id].id), 1)
 this.setData({
 datas: D,
 voteArr: arr
 })
 }else{
 arr.push(D[id].id)
 this.setData({
 voteArr: arr
 })
 if (id || id == 0) {
 D[id].zanUrl = this.data.zanIcon1
 D[id].vote = Number(D[id].vote) + 1
 }

 let data = {
 vote: Number(D[id].vote) + 1,
 id: D[id].id,
 userId: wx.getStorageSync('userId'),
 }
 console.log(data)

 wx.cloud.callFunction({
 name: 'vote',
 //點(diǎn)贊需要的參數(shù):
 // 點(diǎn)贊數(shù) +1
 // 該條的id
 data: { 
  vote: Number(D[id].vote) + 1,
  id: D[id].id,  
 },
 success: res => {
  wx.showToast({
  title: '點(diǎn)贊成功',
  })
  this.setData({
  datas: D
  })

 },
 fail: err => {
  wx.showToast({
  icon: 'none',
  title: '點(diǎn)贊失敗',
  })
  console.error('[云函數(shù)] 調(diào)用失敗:', err)
 }
 })
 }
 
 
 },

再接下來,我們編寫云函數(shù)vote下面的index.js:

// 云函數(shù)入口文件
const cloud = require('wx-server-sdk')
cloud.init()
const db = cloud.database()


// 云函數(shù)入口函數(shù)
exports.main = async (event, context) => { 
//取得傳過來的參數(shù), 可以使用{vote,id } = event 更簡潔
 var vote = event.vote, id = event.id;
 console.log('云函數(shù)zan成功', vote, id)

 // console.warn(data)

 try {
 return await db.collection('funnys').where({
 id: Number(id)
 }).update({
 data: {
 vote: vote
 },
 success: res => {
 console.log('云函數(shù)成功', vote, id)
 
 },
 fail: e => {
 console.error(e)
 }
 })
 } catch (e) {
 console.error(e)
 }

}

編寫好后,我們右鍵vote文件夾, 點(diǎn)擊上傳云函數(shù),上傳完成后就可以測試了。

點(diǎn)擊贊, 我們發(fā)現(xiàn)圖片會變成黃色的贊icon了,這個(gè)是通過this.setData 替換的, 沒有使用后臺的數(shù)據(jù)庫。
之后, 會調(diào)用到云函數(shù)vote, 如果成功, 會有一個(gè)toast顯示,點(diǎn)贊成功;如果失敗, 控制臺也會提示相關(guān)的錯(cuò)誤。

感謝各位的閱讀!關(guān)于“小程序云開發(fā)教程怎么使用云函數(shù)實(shí)現(xiàn)點(diǎn)贊功能”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI