欢迎来到258分享网,纯净的网络源码分享基地!

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 微信开发 > 怎么掌握微信小程序的取值、传值、数据存储

推荐下载

HTML5响应式自适应网咯设计

2020-05-12   浏览:789

HTML5自适应律师工作室类网

2020-04-04   浏览:654

高端HTML5响应式企业通用网

2020-05-06   浏览:560

html5响应式外贸网站英文版

2020-05-08   浏览:545

HTML5影视传媒文化公司类网

2020-05-12   浏览:543

怎么掌握微信小程序的取值、传值、数据存储

发布时间:2020-10-02  

小程序界面设定如下

父级页面:A界面

子级页面:B界面

异级页面:C界面

一.本页面取值(A界面→A界面)

a.例如:input输入文字获取到value(键盘输入时触发)

wxml:

<input type='text' name="userName" maxlength="11" bindinput="userPhoneInput" ></input> js: 复制代码 data: { userPhone: '', }, //手机号输入框事件键盘输入时触发(文字提醒) userPhoneInput: function (e) { this.setData({ userPhone: e.detail.value }) }, //接口取值格式 onShow: function () { ..... data:{ UserPhoneNum:that.data.userPhone, }, ..... },  

b.例如:input不输入文字获取到全部的value(键盘不输入时触发)

wxml:

<form bindsubmit="formSubmit"> <input type='text' value='{{putdata.name}}' name="companyname" placeholder='请输入你的姓名/公司名称'></input> <input type='text' value='{{putdata.bankName}}' name="openbank" placeholder='请输入你的开户行全称'></input> <button formType="submit">完成</button> </form> 注:form表单与button绑定获取input的内容 js:  

//按钮点击事件 formSubmit: function (e) { var companyname = e.detail.value.companyname; var openbank = e.detail.value.openbank; //根据name取input的value wx.request({ url: aaaaaa, data: { name: companyname, bankName: openbank, }, header: { 'content-type': 'application/json', }, success: function (res) { }, fail: function () { } }) }  

二.异页面传值取值(A界面→B界面,A界面→C界面)

a.url传值

用 navigator标签或 wx.navigator传值,A界面向B界面传值;(不懂的自行安利小程序api和组件)

wxml:

 

// navigator标签传值 <navigator url="/page/index/index?id=1432&name=qima&password=hj1234" >传值</navigator> //wx.navigator传值 wx.navigateTo({ url: '/page/index/index?id=' + id +'&username='+ username+'&password='+ password }) 下一个页面取值方法: js: data: { id : "" , name : "" , password : "", }, onLoad: function (options) { var id = options.id; var name = options.name; var password = options.password; this.setData({ id:id, name:name, password:password, }) },  

一般小程序能不用接口解决的就不要用到接口呈现数据,可以用URL传值,到下一个页面取值,然后呈现到页面即可;

b.数据存储

我们会用到小程序的api,通过调用微信提供的方法:wx.setStorage、wx.setStorageSync、wx.getStorage、wx.getStorageSync、wx.clearStorage、wx.clearStorageSync、实现对数据本地缓存、获取、清除。

js缓存:

我们获取接口传回的数据,id,code之类的,我们做全局储存,命名一个key和内容value;

 

wx.request({ url: aaaaa, data: { UserPhoneNum: '86//' + that.data.userPhone, Password: that.data.passWd, IP: that.data.IP, }, header: { 'content-type': 'application/json', }, success: function (res) { console.log(res.data), //存储格式 wx.setStorageSync('key命名', value内容); wx.setStorageSync('salemanId', res.data.salemanId); wx.setStorageSync('salemanLevel', res.data.salemanLevel); if (res.data.state == 200){ }else{ } }, })  

 

js获取:

根据key获取到数据,缓存到本地或上传到接口;

//根据key获取到缓存的值 var salemanId= wx.getStorageSync("salemanId");

js清除:

从本地缓存中同步移除指定 key。这里具体使用同步或是异步需要根据你存储时的方法,或是同步清理本地数据缓存;

//清除数据 wx.removeStorageSync("salemanId")

查看自己缓存数据地点:(如图)

怎么掌握微信小程序的取值、传值、数据存储

c.全局App对象

在我们的app.js文件里面,我们需要写好我们需要全局使用的数据;

//用户学校数据 globalData: { school:null, }

我们需要给它赋值,赋值代码如下:

var self = this ...... self.globalData.school = res.data.schoolID

在我们需要取值的地方引用全局的app.js,然后取值:

 

var app = getApp(); onLoad: function () { var that = this; //调用应用实例的方法获取全局数据 app.getUserSchool(function (school) { //更新数据 }) }, //取值 ...... school: app.globalData.school, ......  

三.总结