欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

微信小程序数据存储与取值详解

程序员文章站 2022-05-07 14:09:42
在小程序开发的过程,经常要需要这个页面输入的数据,在下一个页面中进行取值赋值。 比如: 在a页面input输入框,输入电话号码,点击添加。需要在b页面电话区域中...

在小程序开发的过程,经常要需要这个页面输入的数据,在下一个页面中进行取值赋值。

比如:

微信小程序数据存储与取值详解

微信小程序数据存储与取值详解

在a页面input输入框,输入电话号码,点击添加。需要在b页面电话区域中,显示刚刚输入的电话号码。

因为这是两个页面,就需要先存储,再取值。微信小程序提供了数据存储的api,wx.setstorage(object) 可以将数据存储在本地缓存中指定的 key 中,如果重复会覆盖掉原来该 key 对应的内容。

思路是,在a页面,使用bindinput获取input输入的值,赋值给一个变量(自定义),点击添加按钮时,如果变量不为空,将变量的值存储在本地缓存中,在b页面,使用wx.getstorage(object) 方法取值;

ps : 源代码在页面底部

代码如下:

微信小程序数据存储与取值详解

对input输入框,绑定事件bindinput="bindkeyinput" ,设置value="{{inputvalue}}" ,因为电话号码为数字,设置type="number" 。对按钮添加点击事件bindtap="addbtn"

在js文件中添加代码

微信小程序数据存储与取值详解

b页面代码

微信小程序数据存储与取值详解

在js文件中,声明变量addtel。在页面切换过来的时候,取出我们刚存储的值,赋值给变量addtel。在需要显示电话号码的地方,用变量来接收。

在js文件中添加代码

data:{
  addtel : ''
}

微信小程序数据存储与取值详解

这里在onshow的方法中进行取值,当小程序启动,或从后台进入前台显示,就会触发 onshow。

不过,每个微信小程序都可以有自己的本地缓存,使用这些方法时,要注意本地缓存最大为10mb,wx.setstorage(wx.setstoragesync)wx.getstorage(wx.getstoragesync)可以对本地缓存进行设置、获取和清理。。

也可以使用wx.clearstorage(wx.clearstoragesync)来清理缓存。

代码写完之后,进行测试。

微信小程序数据存储与取值详解

在输入框中输入电话号码,点击添加。

微信小程序数据存储与取值详解

ok,取值成功。

a页面源代码:

<view class="add-page">
  <input placeholder="输入手机号添加客户" type="number" bindinput="bindkeyinput" value="{{inputvalue}}" />
   <button type="warn" class="add-btn" bindtap="addbtn" >添加</button>
</view>
var app = getapp()
page({
 data: {
  inputvalue:''
 },
 bindkeyinput:function(e){
  this.setdata({
   inputvalue: e.detail.value
  })
 },
 addbtn:function(){
   if(this.data.inputvalue){
    wx.redirectto({
     url: '../ordered/ordered'
    })
    wx.setstorage({
     key:"addtel",
     data:this.data.inputvalue
    })
   }else{
    wx.showmodal({
     title: '手机号为空',
     content: '请输入手机号码',
     success: function(res) {
      if (res.confirm) {
       console.log('用户点击确定')
      }
     }
    })
   }
 },
 onload:function(){
  //onload
 }

})

b页面源代码:

<view class="menu-item">
 <navigator class="menu-item-main" >
   <text class="menu-item-name">电话</text>
   <view class="ordtel">
    <text class="ordtext">{{addtel}}</text>
    <image class="menu-item-icon"  src="/image/tel.png"></image>
   </view>      
 </navigator>
</view>
var app = getapp()
page({
  data:{
    addtel : ''
  },
  onshow:function(){
  var that = this;
  wx.getstorage({
   key: 'addtel',
   success: function(res) {
     console.log(res.data)
     that.setdata({
      addtel:res.data
     })
   } 
  })
 }
}) 

其他相关资料可以查阅小程序官方api

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。