- 浏览: 34217 次
最新评论
目前,微信给每个小程序提供了10M的本地缓存空间
有了本地缓存,你的小程序可以做到:
离线应用(已测试在无网络的情况下,可以操作缓存数据)
流畅的用户体验
减少网络请求,节省服务器资源
哪些数据适合方缓存:
热数据
静态数据(用户数据,服务器授权ID等)
网络地址(图片、文件等网络地址)
分页列表数据及详情内容
一般的缓存系统采用键值对的方式完成数据插入和读取,通过对key进行一次Hash算法得到一个唯一值,并与value绑定起来;查询的时候对根据Hash后的key查询,算法空间复杂度O(1);
小程序本地缓存的实现基于上述方式实现。但是数据究竟是存储在ROM,还是存储在RAM后进行持久化,这个问题有待考究。
对本地缓存数据操作分为同步和异步两种。同步方法有成功回调函数,表示数 据处理成功后的操作。下面是小程序提供本地缓存操作接口:
[td]
操作 异步方法 同步方法
插入 wx.setStorage wx.setStorageSync
读取 wx.getStorage wx.getStorageSync
删除 wx.removeStorage wx.removeStorageSync
清空 wx.clearStorage wx.clearStorageSync
获取缓存信息 wx.getStorageInfo wx.getStorageInfoSync
以Sync结尾都是同步方法。同步方法和异步方法的区别是:
同步方法会堵塞当前任务,直到同步方法处理返回。
异步方法不会塞当前任务。
6.下面以插入缓存的两个方法说明同步和异步的区别:
先调用异步方法,再调用同步方法
Page({
save: function(e){
console.log('开始保存')
wx.setStorage({
key: 'key1',
data: 'data1',
success: function(res){
console.log('异步保存成功')
}
})
wx.setStorageSync('key2', 'data2')
console.log('同步保存成功')
}
})
执行结果:
可以看出,同步方法比异步方法先保存成功,说明异步方法没有阻塞当前任务。
先调用同步方法,再调用异步方法
Page({
save: function(e){
console.log('开始保存')
wx.setStorageSync('key2', 'data2')
console.log('同步保存成功')
wx.setStorage({
key: 'key1',
data: 'data1',
success: function(res){
console.log('异步保存成功')
}
})
}
})
执行结果:
可以看出,异步方法只有等到同步方法执行成功才会执行。
缓存API提供了一个获取本地缓存信息的接口wx.getStorageInfo,有了它,开发者可以在已有api上再次封装,比如加入缓存时间、不覆盖插入、批量删除、判断当前缓存大小等。
最后一个是缓存隔离级别的问题:
同一手机,不同小程序应用,至少在逻辑存储上肯定不是共享缓存,满足应用级别隔离。
同一手机,同一个小程序,不同微信用户扫码使用,经测试,也不共享缓存,目前测试条件下,是用户级别隔离。
同一手机,同一个小程序,同一微信用户两次扫码使用,经测试,是共享缓存。
同一手机,同一个小程序,不同微信用户切换使用(分别扫码两次),经测试,同一个用户共享缓存,不同用户间不共享缓存。
目前可以推断在真机调试条件下,每个小程序扫码用户都会分配10M的本地缓存。
以上是个人在真机测试得到的结果,结果不一定完全准确,仅供参考。
原文链接:http://bbs.jointforce.com/topic/23465
有了本地缓存,你的小程序可以做到:
离线应用(已测试在无网络的情况下,可以操作缓存数据)
流畅的用户体验
减少网络请求,节省服务器资源
哪些数据适合方缓存:
热数据
静态数据(用户数据,服务器授权ID等)
网络地址(图片、文件等网络地址)
分页列表数据及详情内容
一般的缓存系统采用键值对的方式完成数据插入和读取,通过对key进行一次Hash算法得到一个唯一值,并与value绑定起来;查询的时候对根据Hash后的key查询,算法空间复杂度O(1);
小程序本地缓存的实现基于上述方式实现。但是数据究竟是存储在ROM,还是存储在RAM后进行持久化,这个问题有待考究。
对本地缓存数据操作分为同步和异步两种。同步方法有成功回调函数,表示数 据处理成功后的操作。下面是小程序提供本地缓存操作接口:
[td]
操作 异步方法 同步方法
插入 wx.setStorage wx.setStorageSync
读取 wx.getStorage wx.getStorageSync
删除 wx.removeStorage wx.removeStorageSync
清空 wx.clearStorage wx.clearStorageSync
获取缓存信息 wx.getStorageInfo wx.getStorageInfoSync
以Sync结尾都是同步方法。同步方法和异步方法的区别是:
同步方法会堵塞当前任务,直到同步方法处理返回。
异步方法不会塞当前任务。
6.下面以插入缓存的两个方法说明同步和异步的区别:
先调用异步方法,再调用同步方法
Page({
save: function(e){
console.log('开始保存')
wx.setStorage({
key: 'key1',
data: 'data1',
success: function(res){
console.log('异步保存成功')
}
})
wx.setStorageSync('key2', 'data2')
console.log('同步保存成功')
}
})
执行结果:
可以看出,同步方法比异步方法先保存成功,说明异步方法没有阻塞当前任务。
先调用同步方法,再调用异步方法
Page({
save: function(e){
console.log('开始保存')
wx.setStorageSync('key2', 'data2')
console.log('同步保存成功')
wx.setStorage({
key: 'key1',
data: 'data1',
success: function(res){
console.log('异步保存成功')
}
})
}
})
执行结果:
可以看出,异步方法只有等到同步方法执行成功才会执行。
缓存API提供了一个获取本地缓存信息的接口wx.getStorageInfo,有了它,开发者可以在已有api上再次封装,比如加入缓存时间、不覆盖插入、批量删除、判断当前缓存大小等。
最后一个是缓存隔离级别的问题:
同一手机,不同小程序应用,至少在逻辑存储上肯定不是共享缓存,满足应用级别隔离。
同一手机,同一个小程序,不同微信用户扫码使用,经测试,也不共享缓存,目前测试条件下,是用户级别隔离。
同一手机,同一个小程序,同一微信用户两次扫码使用,经测试,是共享缓存。
同一手机,同一个小程序,不同微信用户切换使用(分别扫码两次),经测试,同一个用户共享缓存,不同用户间不共享缓存。
目前可以推断在真机调试条件下,每个小程序扫码用户都会分配10M的本地缓存。
以上是个人在真机测试得到的结果,结果不一定完全准确,仅供参考。
原文链接:http://bbs.jointforce.com/topic/23465
发表评论
-
微信小程序之提高应用速度小技巧
2017-03-17 17:08 10721、提高页面加载速度 ... -
微信小程序支付(java后端)
2017-02-27 14:38 10356第一步 进入小程序,下单,请求下单支付,调用小程序登录AP ... -
高效编写微信小程序
2017-02-22 15:26 468微信小程序是一个工程,就和盖房子一样,打好了地基,才能保证后续 ... -
微信小程序开放部分模糊搜索,你怎么看?
2017-02-13 16:22 417今天看到一则新闻,微信小程序开始开放模糊搜索了,所以亲自测试了 ... -
微信小程序编写tabBar模板,map组件markers属性动态初始化
2017-02-07 16:04 2150一:编写tabBar模板 众所周知,微信小程序的tabBar ... -
目前为止小程序审核不通过原因整理汇总
2017-01-23 14:57 8951、小程序简介没有介绍小程序功能 2、类目与页面提供的内容不一 ... -
微信小程序之图书管理系统(wepy版)
2017-01-19 14:42 10822016年小程序的推出,刷爆了朋友圈。作为一名好奇的程序猿 ... -
微信小程序form组件
2017-01-18 15:29 1085form 组件 表单 主要属性: 效果图: form. ... -
wafer-master小程序
2017-01-13 15:00 599wafer-master小程序 1、Centos 重启ngin ... -
信小程序参数二维码的8大使用场景
2017-01-12 15:13 695一、小程序参数二维码的8大使用场景 1 地推。 使用 ... -
小程序用户反馈-HotApp小程序统计仿微信聊天用户反馈组件...
2017-01-06 14:46 559用户反馈是小程序开发 ... -
小程序是微信最后的机会吗?它能做多大?
2017-01-05 15:46 527微信小程序又刷屏了。 ... -
获得session_key和openId(加解密、签名系列)
2016-12-26 15:57 10421:session_key和openId是什么?session ... -
5个关键词看小程序和App的UI设计异同
2016-12-23 14:20 559关键词一:友好礼貌对应于苹果:Less is more 苹果在 ... -
微信小程序正式发布官方视觉组件库,传递了怎样的信号?
2016-12-21 17:16 57912月16日,微信正式发布了WeUI.js动态视觉组件库。We ... -
微信小程序canvas组件简单运用之涂鸦
2016-12-19 14:17 518源码 index.html <view class ... -
深度加速:微信小程序将成为下一个风口
2016-12-09 16:58 3462016年11月3日,“小程 ... -
深度加速:微信小程序将成为下一个风口
2016-12-09 16:55 4432016年11月3日,“小程序 ...
相关推荐
本地缓存是指在应用程序内部的缓存组件,其最大优点是应用程序和缓存处于同一个进程内部,请求缓存非常快速,没有过多的网络开销等。在单应用不需要集群支持或者集群情况下各节点无需互相通知的场景下使用本地缓存较...
目前,微信给每个小程序提供了10M的本地缓存空间 有了本地缓存,你的小程序可以做到: 离线应用(已测试在无网络的...小程序本地缓存的实现基于上述方式实现。但是数据究竟是存储在ROM,还是存储在RAM后进行持久化,这
本篇文章将详细讲解如何对微信小程序的接口进行封装,以及如何实现本地缓存方法的封装与使用。 首先,我们要了解微信小程序的API体系。微信小程序的API包括网络请求、用户信息获取、文件操作、地理位置、设备信息等...
在微信小程序的开发中,数据缓存机制是一个重要的功能,它允许开发者将数据存储在用户的本地,以便在后续的页面加载或应用使用中快速访问,提高用户体验。本篇文章主要探讨了如何实现小程序的数据缓存机制,并通过...
微信小程序基于本地缓存实现点赞功能的方法 微信小程序基于本地缓存实现点赞功能的方法是指在微信小程序中使用本地缓存来实现点赞功能的方法。这种方法主要涉及到微信小程序界面布局、事件响应及缓存操作等相关实现...
本地缓存、异步缓存和同步缓存是小程序缓存的三种主要形式。以下是对这些概念的详细解释: 1. **本地缓存**:本地缓存允许开发者在小程序内部存储数据,类似于Web开发中的localStorage。微信小程序提供了`wx....
3.wx.removeStorage接口函数:这个接口函数用于从本地缓存中异步删除指定key对应内容 清除前: 清除后: 4.wx.removeStorageSync接口函数:这个函数用于从本地缓存中同步删除指定key对应的内容 清除前: 清除...
在微信小程序开发中,与本地数据库进行数据交互是常见的需求,尤其在实现用户信息存储、商品管理、订单处理等功能时。本案例资源提供了一个全面的示例,涵盖了从后端Java服务到微信小程序前端,再到数据库操作的完整...
3. **定位到Outlook文件夹**:在`GroupContainers`文件夹中找到`UBF8T346G9.Office`(这通常代表了Office应用程序组),然后进入该文件夹下的`Outlook`文件夹即可看到本地缓存的数据。 #### 四、Outlook for Mac ...
在微信小程序中,本地缓存是一种重要的数据存储方式,它允许开发者暂时保存用户数据,即使在小程序关闭后也能保持这些数据。本地缓存通常用于存储一些不敏感且不需要实时更新的信息,例如用户设置、部分界面状态等。...
3. 集成ISCSI驱动:确保服务器的ISCSI驱动支持本地缓存功能,这通常需要更新或升级驱动程序。 4. 配置ISCSI目标和发起者:在ISCSI存储端设置目标,服务器端设置发起者,并建立连接。 5. 开启缓存功能:在ISCSI客户端...
在IT行业中,缓存是一种非常重要的技术,它能够提高应用程序的性能和响应速度,通过将经常访问的数据存储在快速访问的内存中,避免了频繁的数据库查询或计算。本示例将聚焦于“Spring简单的缓存”实现,帮助开发者...
本项目“一个基于微信小程序的本地生活项目”旨在展示如何利用微信小程序进行本地生活服务类应用的开发,涵盖了微信小程序的基础概念、页面布局、API调用、接口数据请求以及数据绑定逻辑等多个核心知识点。...
本篇文章将详细解析微信小程序本地缓存数据的增删改查操作。 1. **添加数据** 微信小程序提供了`wx.setStorageSync`方法用于存储数据到本地缓存。在这个例子中,我们有一个用户对象`user`,包含姓名`name`和性别`...
8. **本地存储**:小程序支持本地缓存数据,可以用来存储用户偏好、临时数据等,提升用户体验。 9. **微信小程序调试**:开发者工具提供了真机预览和模拟器调试功能,便于检查和修复代码问题。 10. **发布与更新**...
3. **缓存更新**:当服务器数据发生变化时,自动或手动同步更新本地缓存。 4. **性能监控**:跟踪缓存命中率,评估缓存效果。 "DATABASE"文件可能是数据库的备份或脚本文件,用于在本地重建或初始化缓存所需的数据...
Caffeine是一个高性能的本地缓存库,专为Java 8设计,被广泛应用于需要快速访问数据的场景,尤其在Spring 5之后成为了默认的缓存实现,替代了原本的Guava缓存。本地缓存的优势在于它可以避免网络通信带来的延迟,...