微信小程序开发数据缓存基础知识辨析及运用实
提示这里可以添加本文要记录的大概内容
例如随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。
提示以下是本篇文章正文内容,狼蚁网站SEO优化案例可供参考
一、微信数据缓存是什么?
在实际开发中,在用到一个数据时,我们需要调用api接口去得到,然后渲染在页面中,对于一些数据,是经常需要使用的,如果每次使用时都需要调用api接口,会十分麻烦。数据缓存就解决了这个问题,我们可以在初次调用某api得到数据的将数据缓存,那么在之后的使用过程中,可以直接通过缓存区得到,这样就提高了程序的效率。举个例子。在第二次登录微信时,我们还没有进行登录操作,发现我们的头像数据已经渲染到页面中,这就是因为再一次登录时,图片的地址是从缓存区中得到的缘故,在本文中也会对此实例进行操作,微信小程序中的数据缓存可类比js中的localstorage
二、数据缓存api使用方法和辨析
1.存入数据
wx.setStorageSync(string key, any data)
wx.setStorageSync("name","张三")
wx.setStorage(Object object)
wx.setStorage({ data: "李四", key: 'name1', })
当执行了这段代码之后就会发现在调试区storage中出现以下数据
2.读数据
wx.getStorageSync(string key)
var b=wx.getStorageSync('name') console.log(b);
Object wx.getStorageInfoSync()
var a=wx.getStorage({ key: 'name1', }) a.then(e=>{ console.log(e.data); })
wx.getStorageInfoSync()得到的是一个promise对象,使用then方法通过e.data得到缓存区数据
当执行了这段代码之后就会发现在调试区console中出现以下数据
3.删除数据 wx.removeStorage(Object object)
wx.removeStorage({ key: 'name1', })
wx.removeStorageSync(‘name')
wx.removeStorageSync('name')
当执行了这段代码之后就会发现在调试区storage中出现以下数据会被删除
4.删除全部数据(这里不再细说)
wx.clearStorage() wx.clearStorageSync()
三、api辨析
可以看到上面的多可api可分为两大类,一种是带sync的一种是不带的,其实带sync的是异步api,而不带的是同步api,这也是带sync的这部分api得到的是一个promise对象,这里以wx.setStorageSync() ,wx.setStorage() 做以示例
1.wx.setStorage()
代码如下(示例)在wxml中写入了两个按钮,点击第一个触发函数tongbu,用来演示同步情况
tongbu:function(){ wx.setStorageSync("name","张五") //同步api var a=wx.getStorageSync('name') console.log(a); }
最开始name对应的数据是张三,在这里我们修改为张五,然后读取数据,发现console为
说明是单线程顺序执行,在修改了name后才执行了console.log
2.wx.setStorage()
代码如下(示例)点击第一个触发函数yibu,用来演示异步情况
yibu:function(){ wx.setStorage({ data: "李柳", key: 'name1', }) var a=wx.getStorageSync('name1') console.log(a); } })
最开始name对应的数据是李四,在这里我们修改为李柳,然后读取数据,发现console为
代码console.log在修改数据之后,发现在修改数据过后,a没有改变,说明这里的wx.setStorage()是异步api,在执行时,无论这里有无完成执行,都会执行cinsole.log
加载微信个人信息案例
index.wxss
/index.wxss/ .userinfo { display: flex; flex-direction: column; align-items: center; } .userinfo-avatar { width: 128rpx; height: 128rpx; margin: 20rpx; border-radius: 50%; } .userinfo-nickname { color: #aaa; } .usermotto { margin-: 200px; } image{ margin-: 20px; margin-bottom: 20px; width: 50px; height: 50px; }
index.wxml
<!--index.wxml--> <view class="container"> <button bindtap="getmessage">获取用户信息</button> <view>头像</view> <view><image src="{{pictureurl}}"></image></view> <view><text>用户名为 {{name}}</text></view> </view>
index.js
// pages/index/index.js Page({ / 页面的初始数据 / data: { name:'张三', pictureurl:'../index/4.png' }, getmessage:function(){ var a=new Promise((resolve,reject)=>{ wx.getUserInfo({ suess: function(res) { resolve(res) } }) })//获取用户数据,前提是已经取得了访问权限 a.then(res=>{ this.setData({ name:res.userInfo.nickName, pictureurl:res.userInfo.avatarUrl })//将访问得到的数据渲染到页面中 wx.setStorage({ data: res.userInfo.nickName,//name中存入用户名信息 key: 'name', }) wx.setStorage({ data: res.userInfo.avatarUrl,//pictureurl中存入用户头像的url地址 key: 'pictureurl', }) })//将渲染的数据缓存 }, / 生命周期函数--监听页面加载,加载页面,触发onLoad。此时就可以将数据渲染 / onLoad: function (options) { var name=wx.getStorageSync('name')//从缓存中读取用户名信息 var url=wx.getStorageSync('pictureurl')//从缓存中读取头像url console.log(name); console.log(url); this.setData({ name:name, pictureurl:url }) } })
渲染后的结果示例,第一次点击获取用户数据按钮后当刷新或者关闭后重启程序都会是此页面
到此这篇关于微信小程序开发数据缓存基础知识辨析及运用实例详解的文章就介绍到这了,更多相关微信小程序开发数据缓存内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章希望大家以后多多支持狼蚁SEO!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程