結合自己在平時的開發中遇到的各種問題,和瀏覽各種問題的解決方案總結出一些自己在日常開發中常用的技巧和知點,希望各位不吝斧正。
1.短生命周期數據存儲
以小程序啟動到徹底關閉為周期的的數據建議存儲在app.js文件夾中,引用app.js:
const app =getApp();
假設Value是在小程序本次生命周期中經常使用到的一個數據,比如說請求API的Token,動態的令牌等。那么就可以把這個值賦值到全局變量中去。實際上,並不是只有app.js中的globalData是全局變量,可以自己定義數據集。
App({
eduOS:{
token:''
},
...
})
對於app.js里面的token進行賦值操作很簡單,只要頁面引用了app.js
app.eduOS.token = Value;
這個數據在小程序的本次啟動到徹底關閉后台的周期中就是長期存在的了,還可以根據需要進行修改,Value可以是對象。
2.長生命周期或者隱私數據存儲
這種數據的顯著特點是在小程序關閉再次重啟后依然存在,或者涉及到用戶的隱私信息但是需要復用,這種時候可以用本地緩存來解決這種問題。
本地緩存的生命周期: 小程序被開始使用 -----> 小程序被徹底從使用列表中移除。
小程序設置緩存的方式:
wx.setStorage({
key: 'educookie',
data: {
xh: that.data.xh,
pwd: that.data.pwd
}
})
小程序獲取緩存的方式:
var that = this;
wx.getStorage({
key: 'educookie',
success: function(res) {
that.setData({xh:res.data.xh,pwd:res.data.pwd});
},
})
比如保存用戶的登陸態信息,但是不能保存用戶的隱私數據,就可以采用這種方式。
或者是一個非時效性的數據,可以通過這種方式進行存儲。
3.動態信息或配置信息存儲
保存用戶的配置信息,在更換手機時能迅速完成配置同步。
商家小程序推薦商品修改,或者是內容修正,或者是增加活動,不可能每次都要重寫然后再次讓小程序進行審核。
對此,可以在后端服務器中保存這個信息。
以一個小程序的輪播廣告牌為例:
{
ad1:'imgurl1',
ad2:'imgurl2',
ad3:'imgurl3'
}
把這個數據存放在后台服務器,每一次刷新該頁面都請求一次后台數據,對內容進行修改。
wx.request({
url:'XXX',
data:{},
success(res){
that.setData({
adList:res.data
})
}
})
類似這種方式,完成對一些數據的動態控制或者是雲同步。
4.頁面間數據傳遞
1.url參數化
頁面間之間的數據傳遞一般是簡單的,這種類型的數據的生命周期是一次性的,用完即刪。
wx.navigatorTo({
url:'../index/index?param1=value1¶m2=value2'
})
//在index頁面獲取
onLoad(options){
console.log(options.param1);//value1
}
可以參照Http請求中的Get表單傳參方式來寫頁面之間的傳參。
2.storge形式傳遞
如果需要傳送的數據太多,可通過Map<key ,Storge>進行傳遞,具體內容參考官方文檔。
wx.setStorge({
key:'xxx',
data:mydata
})
//獲取
wx.getStorgeSync('')
傳遞參數只需要傳遞一個key,在其他界面通過這個key再次去獲取本地緩存,對於這種類型的數據,建議使用完后即時的刪除緩存。
wx.removeStorage({
key: 'xxx',
success(res) {
console.log(res)
}
})
3.使用全局變量作為中介
const app = getApp();
page({
app.globalData.isBackvalue = ture;//確定是返回的值
app.globalData.tmpData = value;//你要傳遞的值,也可以設置緩存
})
在返回的頁面獲取
const app = getApp();
...
onShow(){
if(app.globalData.isBackValue){
this.setData({
XXX:app.globalData.tmpData
})
//或者是通過獲取緩存的方法進行賦值
}
}
4.頁面棧
該方法可以對所有入棧的頁面進行賦值,有科班的同學可以理解為對樹的dfs遍歷入棧/出棧,棧內頁面均可以進行數據傳遞。
var allpages = getCurrentPages();//獲取全部頁面數據
//棧的下標從 0 開始,進入頁面第一個加載的頁面數據是 allpages[0],當前頁面是allpages[allpages.length - 1], 上一個頁面是allpages[allpages.length - 2]
var prepagedata = allpages[allpages.length - 2].data;//獲取上一頁面的數據。
var prepage = allpages[allpages.length - 2];//獲取上一頁面,包括數據和方法
//設置數據方法
prepage.setData({
XXX:value //XXX 是上個頁面data中的參數,value是要設置的值
})
//調用函數方法,prepage中必須定義callfunction函數才可以調用
prepage.callfunction();
5.通信管道 EventChannel
Tips(如何理解通信管道):可以把該管道當成url或storge傳遞信息形式的一種,不過是被封裝為Object形式了
A頁面傳遞
wx.navigateTo({
url: 'B頁面',
success:res=>{
res.eventChannel.emit('channeldata', {name:'kindear'})
}
})
B頁面接收
onLoad: function (options) {
let eventChannel = this.getOpenerEventChannel();
eventChannel.on('channeldata', data => {
console.log(data)
//打印成功 {name:'kindear'}
})
}
開發聯系Q 1025584691