小程序云开发教程如何使用云函数实现点赞功能


Posted in Javascript onMay 18, 2019

本文我们就要使用高大上的云函数了,实现点赞功能

什么是云函数?

云函数 云函数即在云端(服务器端)运行的函数。 在物理设计上,一个云函数可由多个文件组成,占用一定量的CPU 内存等计算资源;各云函数完全独立;可分别部署在不同的地区。 … 当云函数被小程序端调用时,定义的代码会被放在Node.js 运行环境中执行。

新建的项目中其实有云函数的示例可以参考。

首先,我们在cloudfunctions 文件夹右键,新建一个nodeJs云函数, 然后命名为vote, 点击回车,等一会它会弹窗,告诉我们要安装云函数的环境, 但前提是你已经安装了node环境和npm。

小程序云开发教程如何使用云函数实现点赞功能

安装node可以直接去node的官方网站,下载一个msi文件,一路安装就可以了。
安装完node之后,其实默认是安装了npm的.
点击确定,等会它安装完成后,我们点击关闭命令行的窗口。

接下来, 在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',
 //点赞需要的参数:
 // 点赞数 +1
 // 该条的id
 data: { 
  vote: Number(D[id].vote) + 1,
  id: D[id].id,  
 },
 success: res => {
  wx.showToast({
  title: '点赞成功',
  })
  this.setData({
  datas: D
  })

 },
 fail: err => {
  wx.showToast({
  icon: 'none',
  title: '点赞失败',
  })
  console.error('[云函数] 调用失败:', err)
 }
 })
 }
 
 
 },

再接下来,我们编写云函数vote下面的index.js:

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


// 云函数入口函数
exports.main = async (event, context) => { 
//取得传过来的参数, 可以使用{vote,id } = event 更简洁
 var vote = event.vote, id = event.id;
 console.log('云函数zan成功', vote, id)

 // console.warn(data)

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

}

编写好后,我们右键vote文件夹, 点击上传云函数,上传完成后就可以测试了。

点击赞, 我们发现图片会变成黄色的赞icon了,这个是通过this.setData 替换的, 没有使用后台的数据库。
之后, 会调用到云函数vote, 如果成功, 会有一个toast显示,点赞成功;如果失败, 控制台也会提示相关的错误。

那么,到此为止,点赞功能就基本完成了, 请看:详细代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS俄罗斯方块,包含完整的设计理念
Dec 11 Javascript
jquery 实现两级导航菜单附效果图
Mar 07 Javascript
使用jquery中height()方法获取各种高度大全
Apr 02 Javascript
jQuery中:contains选择器用法实例
Dec 30 Javascript
javascript记住用户名和登录密码(两种方式)
Aug 04 Javascript
jQuery tip提示插件(实例分享)
Apr 28 jQuery
详解vue嵌套路由-params传递参数
May 23 Javascript
Angular实现表单验证功能
Nov 13 Javascript
echarts学习笔记之图表自适应问题详解
Nov 22 Javascript
Vue修改mint-ui默认样式的方法
Feb 03 Javascript
Angular4 ElementRef的应用
Feb 26 Javascript
Servlet返回的数据js解析2种方法
Dec 12 Javascript
微信小程序实现元素渐入渐出动画效果封装方法
May 18 #Javascript
微信小程序收货地址API兼容低版本解决方法
May 18 #Javascript
小程序云开发获取不到数据库记录的解决方法
May 18 #Javascript
小程序云开发之用户注册登录
May 18 #Javascript
小程序云开发实现数据库异步操作同步化
May 18 #Javascript
微信小程序云开发之数据库操作
May 18 #Javascript
微信小程序云开发如何使用云函数生成二维码
May 18 #Javascript
You might like
php使用qr生成二维码的示例分享
2014/01/20 PHP
实例讲解PHP页面静态化
2018/02/05 PHP
PHP数组遍历的几种常见方式总结
2019/02/15 PHP
php 多进程编程父进程的阻塞与非阻塞实例分析
2020/02/22 PHP
php模拟post提交请求调用接口示例解析
2020/08/07 PHP
禁止F5等快捷键的JS代码
2007/03/06 Javascript
事件模型在各浏览器中存在差异
2010/10/20 Javascript
深入理解JavaScript系列(2) 揭秘命名函数表达式
2012/01/15 Javascript
使用jQuery validate 验证注册表单实例演示
2013/03/25 Javascript
jquery 合并内容相同的单元格(示例代码)
2013/12/13 Javascript
js中substr,substring,indexOf,lastIndexOf的用法小结
2013/12/27 Javascript
javascript制作坦克大战全纪录(2)
2014/11/27 Javascript
关注jquery技巧提高jquery技能(前端开发必学)
2015/11/02 Javascript
怎么限制input的text里输入的值只能是数字(正则、js)
2016/05/16 Javascript
javascript回到顶部特效
2016/07/30 Javascript
全屏滚动插件fullPage.js使用实例解析
2016/10/21 Javascript
开源免费天气预报接口API及全国所有地区代码(国家气象局提供)
2016/12/26 Javascript
详解vuex的简单使用
2018/03/12 Javascript
优雅的在React项目中使用Redux的方法
2018/11/10 Javascript
微信小程序实现打卡日历功能
2020/09/21 Javascript
jQuery实现的记住帐号密码功能完整示例
2019/08/03 jQuery
js通过循环多张图片实现动画效果
2019/12/19 Javascript
JavaScript实现简单进度条效果
2020/03/25 Javascript
vue fetch中的.then()的正确使用方法
2020/04/17 Javascript
[02:58]魔廷新尊——痛苦女王至宝语音台词节选
2020/06/14 DOTA
Python专用方法与迭代机制实例分析
2014/09/15 Python
利用一个简单的例子窥探CPython内核的运行机制
2015/03/30 Python
对pandas中to_dict的用法详解
2018/06/05 Python
python绘制散点图并标记序号的方法
2018/12/11 Python
Python 给屏幕打印信息加上颜色的实现方法
2019/04/24 Python
Python高级特性 切片 迭代解析
2019/08/23 Python
CSS3 中的@keyframes介绍
2014/09/02 HTML / CSS
九年级数学教学反思
2014/02/02 职场文书
骨干教师考核方案
2014/05/09 职场文书
驾驶员安全责任书范本
2014/07/24 职场文书
七夕活动策划方案
2014/08/16 职场文书