亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

微信小程序基于本地緩存實現(xiàn)點贊功能的方法

 更新時間:2017年12月18日 08:57:29   作者:anLazyAnt  
這篇文章主要介紹了微信小程序基于本地緩存實現(xiàn)點贊功能的方法,涉及微信小程序界面布局、事件響應(yīng)及緩存操作等相關(guān)實現(xiàn)技巧,需要的朋友可以參考下

本文實例講述了微信小程序基于本地緩存實現(xiàn)點贊功能的方法。分享給大家供大家參考,具體如下:

wxml中的寫法

注意:

1. 使用wx:if="{{condition}}" wx:else實現(xiàn)圖標的切換效果;
2. 為圖片綁定點擊事件bindtap="toCollect",兩個image標簽都要綁定!

<image wx:if="{{collection}}" src="/images/icon/pic1.png" bindtap="toCollect"></image>
<image wx:else src="/images/icon/pic2.png" bindtap="toCollect"></image>

js中的寫法:

Page({
 data: {
 },
 onLoad: function(option) {
  // 獲取接收到的id值
  var getId = option.id;
  // 讓接收到的id值傳遞到data:{}里面
  this.setData({
   currentId: getId
  });
  // 讀取所有的文章列表點贊緩存狀態(tài)
  var cache = wx.getStorageSync('cache_key');
  // 如果緩存狀態(tài)存在
  if (cache) {
   // 拿到所有緩存狀態(tài)中的1個
   var currentCache = cache[getId];
   // 把拿到的緩存狀態(tài)中的1個賦值給data中的collection,如果當前文章沒有緩存狀態(tài),currentCache 的值就是 false,如果當前文章的緩存存在,那么 currentCache 就是有值的,有值的說明 currentCache 的值是 true
   this.setData({
    collection: currentCache
   })
  } else {
   // 如果所有的緩存狀態(tài)都不存在 就讓不存在的緩存存在
   var cache = {};
   // 既然所有的緩存都不存在,那么當前這個文章點贊的緩存也不存在,我們可以把當前這個文章點贊的緩存值設(shè)置為 false
   cache[getId] = false;
   // 把設(shè)置的當前文章點贊放在整體的緩存中
   wx.setStorageSync('cache_key',cache);
  }
 },
 // 點擊圖片的點贊事件 這里使用的是同步的方式
 toCollect: function(event) {
  // 獲取所有的緩存
  var cache = wx.getStorageSync('cache_key');
  // 獲取當前文章是否被點贊的緩存
  var currentCache = cache[this.data.currentId];
  // 取反,點贊的變成未點贊 未點贊的變成點贊
  currentCache = !currentCache;
  // 更新cache中的對應(yīng)的1個的緩存值,使其等于當前取反的緩存值
  cache[this.data.currentId] = currentCache;
  // 重新設(shè)置緩存
  wx.setStorageSync('cache_key',cache);
  // 更新數(shù)據(jù)綁定,從而切換圖片
  this.setData({
   // collection 默認的是 false
   collection: currentCache
  });
  // 交互反饋
  wx.showToast({
   title: currentCache?'點贊':'取消',
   icon: 'success',
   duration: 2000
  });
 }
})

js中操作反饋—wx.showModal的寫法:

// 點擊圖片的點贊事件 這里使用的是同步的方式
toCollect: function(event) {
  // 獲取緩存,得到當前文章是否被點贊
  var cache = wx.getStorageSync('cache_key');
  // 獲取當前文章是否被點贊的緩存
  var currentCache = cache[this.data.currentId];
  // 取反,點贊的變成未點贊 未點贊的變成點贊
  currentCache = !currentCache;
  // 更新cache中的對應(yīng)的1個的緩存值,使其等于當前取反的緩存值
  cache[this.data.currentId] = currentCache;
  // 調(diào)用 showModal方法
  this.showModal(cache,currentCache);
},
showModal: function(cache,currentCache) {
 var that = this;
 wx.showModal({
  title: "點贊"
  content: currentCache?"要點贊嗎?":"要取消贊嗎?",
  showCancel: "true",
  cancelText: "取消",
  cancelColor: "#666",
  confirmText: "確定",
  confirmColor: "#222",
  success: function(res) {
   if (res.confirm) {
    // 重新設(shè)置緩存
    wx.setStorageSync('cache_key',cache);
    // 更新數(shù)據(jù)綁定,從而切換圖片
    that.setData({
     collection: currentCache
    })
   }
  }
 })
}

希望本文所述對大家微信小程序開發(fā)有所幫助。

相關(guān)文章

  • 微信頁面彈出鍵盤后iframe內(nèi)容變空白的解決方案

    微信頁面彈出鍵盤后iframe內(nèi)容變空白的解決方案

    當鍵盤彈出后,頁腳也被頂起來;而當搜索完(要刷新整體頁面),鍵盤縮回后,iframe里 鍵盤當住的地方變成白色。怎么解決這個問題呢?下面腳本之家小編給大家分享微信頁面彈出鍵盤后iframe內(nèi)容變空白的解決方案,一起看看吧
    2017-09-09
  • JavaScript中自定義swiper組件詳解

    JavaScript中自定義swiper組件詳解

    這篇文章主要介紹了微信小程序 swiper組件輪播圖詳解及實例的相關(guān)資料,需要的朋友可以參考下,希望能給你帶來幫助
    2021-08-08
  • JS URL傳中文參數(shù)引發(fā)的亂碼問題

    JS URL傳中文參數(shù)引發(fā)的亂碼問題

    今天的項目中碰到了一個亂碼問題,從JS里傳URL到服務(wù)器,URL中有中文參數(shù),服務(wù)器里讀出的中文參數(shù)來的全是“?”,查了網(wǎng)上JS編碼相關(guān)資料得以解決。
    2009-09-09
  • 微信小程序如何實現(xiàn)全局重新加載

    微信小程序如何實現(xiàn)全局重新加載

    這篇文章主要給大家介紹了關(guān)于微信小程序如何實現(xiàn)全局重新加載的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用微信小程序具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • js的2種繼承方式詳解

    js的2種繼承方式詳解

    這篇文章主要介紹了javascript的2種繼承方式,分析對象冒充和原型鏈方式的不同,需要的朋友可以參考下
    2014-03-03
  • document.createElement()用法及注意事項(ff下不兼容)

    document.createElement()用法及注意事項(ff下不兼容)

    今天處理了一個日期選擇器的ie和ff的兼容問題,本來這種情況就很難找錯誤,找了好久才把錯誤定位到j(luò)s中創(chuàng)建元素的方法document.createElement(),這個方法在ie下支持這樣創(chuàng)建元素
    2013-03-03
  • 通過網(wǎng)頁查看JS源碼中漢字顯示亂碼的解決方法

    通過網(wǎng)頁查看JS源碼中漢字顯示亂碼的解決方法

    這篇文章給大家主要介紹了通過網(wǎng)頁查看JS源碼的時候,發(fā)現(xiàn)漢字顯示是亂碼的解決方法,文中通過圖文詳解的介紹了解決的步驟,詳細會對大家很有幫助,有需要的朋友們下面來一起看看吧。
    2016-10-10
  • JavaScript數(shù)據(jù)類型轉(zhuǎn)換簡單方法舉例

    JavaScript數(shù)據(jù)類型轉(zhuǎn)換簡單方法舉例

    JavaScript是一種無類型語言,但同時JavaScript提供了一種靈活的自動類型轉(zhuǎn)換的處理方式,下面這篇文章主要給大家介紹了關(guān)于JavaScript數(shù)據(jù)類型轉(zhuǎn)換的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • JavaScript修改、刪除數(shù)組中某個對象的某個屬性幾種方法

    JavaScript修改、刪除數(shù)組中某個對象的某個屬性幾種方法

    在JavaScript開發(fā)中,經(jīng)常需要修改數(shù)組中對象的屬性,下面這篇文章主要介紹了JavaScript修改、刪除數(shù)組中某個對象的某個屬性幾種方法,需要的朋友可以參考下
    2024-09-09
  • 函數(shù)式JavaScript編程指南

    函數(shù)式JavaScript編程指南

    函數(shù)式JavaScript編程指南...
    2007-02-02

最新評論