uniapp使用localStorage存储值遇到的问题

1. 数据存储localStorage

llocalStorage是本地存储,是将数据存储到浏览器的方法,一般在跨页面时使用。

uniapp提供数据存和取的api。

复制代码
uni.setStorage({
      key:'runTime',
      data:this.sumRTtime.toFixed(3),
      success:function(){
           console.log('success');
      })

从图中可以看出,值已经存储在localStorage中。

2. 数据读取

我需要在第二个页面读取这个runTime的值。我选择created阶段来读取这个值,并且设置到data中并渲染到页面上。

复制代码
uni.getStorage({    
    key: 'runTime',
    success: function (res) {
        this.wrongNum=res.data
    }
});

3. 数据传到了,但是页面不渲染

刚开始以为是生命周期传值的原因,但后来想想created()阶段一定是可以设置值的,然后打算用this.$forceUpdate()强制刷新一下,也是无效,并且报错,"is not a function"。

因为我设置值是使用"this."来得到当前页面的data值,然后我就想是不是这个this的原因,我在uni.getStorage()的success()中输出this,果然问题出现在这里。

可以看出,这里的this指向改变了,不再指向vue实例。

4. 解决方法

复制代码
    created(){
        var _this=this
        uni.getStorage({    
            key: 'runTime',
            success: function (res) {
                _this.wrongNum=res.data
            }
        });
    },

先存一下this,问题解决。

相关推荐
百锦再10 分钟前
复杂查询中基于代价的连接条件下推实践与思考
前端
广州华水科技12 分钟前
如何实现高精度的单北斗GNSS位移监测系统安装?
前端
肉肉不吃 肉22 分钟前
Vue Router 路由模式
前端·javascript·vue.js
北寻北爱23 分钟前
Vue-Router
前端·javascript·vue.js
肉肉不吃 肉29 分钟前
什么是闭包
前端·javascript
窝子面32 分钟前
十六、按钮组件
前端
天天向上102433 分钟前
vue 页面内实现el-table和div自动滚动
前端·javascript·vue.js
前端老石人41 分钟前
HTML文档元素与元数据详解
前端·html
wing981 小时前
用 AI 实现图片懒加载,这也太简单了!
前端·vue.js·图片资源
sigernet1 小时前
Claude Code 不再推荐 npm 安装:官方改为 Native Installer
前端·npm·node.js