• 文章点赞以及取消点赞功能


    今天开发了一个文章的留言版块,于是想到要为某个留言点赞,点过赞的再次点击会取消点赞,代码如下:


    /*更新点赞*/

    update_zan:function(e){ 
      var that = this; 
      var data = e.currentTarget.dataset; 
      var mid = data.mid; 
      var cookie_mid = wx.getStorageSync('zan') || [];//获取全部点赞的mid 
      var isadd = 1; 
      var newmessage = []; 
      if (cookie_mid.includes(mid)){//说明已经点过赞,取消赞 
        isadd = 0; 
        var m = 0; 
        for (var j in cookie_mid){ 
        if(cookie_mid[j] != mid){ 
          newmessage[m] = cookie_mid[j]; 
          m++ 
        } 
      } 
      wx.setStorageSync('zan', newmessage);//删除取消赞的mid 
      }else{ 
        cookie_mid.unshift(mid); 
        wx.setStorageSync('zan', cookie_mid);//新增赞的mid 
      } 
      wx.request({ 
      url: app.globalData.api.api_system, 
      data: { 
      action: 'zannum', 
      mid: mid, 
      isadd: isadd, 
      wxid: app.globalData.wxid 
      }, 
      method: 'GET', 
      // header: {}, 
      success: function (res) { 
      var message = that.data.message; 
      for (var i in message) { 
      if(message[i].mid == mid){ 
        if(isadd){ 
          message[i].zan = parseInt(message[i].zan) + 1 
        }else{ 
          message[i].zan = parseInt(message[i].zan) - 1 
        } 
    
      } 
    } 
    that.setData({ 
      message: message 
     }) 
    } 
    })

    重点注意代码:
    (1)要把所有已经点过赞的留言id给存储到本地缓存之中,这样如果重复点赞的,就可以判断出来,并取消点赞,取消点赞的同时要去掉缓存中的id;
    (2)新增点赞和取消点赞用到同一个api,通过isadd=1或者isadd=0来判断是新增还是取消点赞
    (3)为了不频繁去读取留言列表,可以直接调用this.data.message,并通过循环遍历改变某个留言的点赞数,然后直接重新赋值,就能动态改变点赞数!
    ---------------------
    //转载

  • 相关阅读:
    C++ Sqlite3的基本使用
    DirectX11 初探XMVECOTR&XMMATRIX
    lib和dll文件的初了解
    游戏设计模式——C++单例类
    C++11智能指针的深度理解
    你的文章里为什么不放源码Github链接了
    堡垒机的核心武器:WebSSH录像实现
    Asciinema文章勘误及Web端使用介绍
    Asciinema:你的所有操作都将被录制
    Django实现WebSSH操作物理机或虚拟机
  • 原文地址:https://www.cnblogs.com/Alitar/p/10823585.html
Copyright © 2020-2023  润新知