一、使用本地存儲時可以直接存儲JSON,而無需先轉(zhuǎn)成字符串
我們都知道,在HTML5中使用localStorage不能直接存儲JSON格式數(shù)據(jù),而是需要先通過JSON.stringify()將其轉(zhuǎn)化成String格式的數(shù)據(jù),這樣才能存入到本地存儲中。然而,小程序則不同,可以說更加貼心了,直接使用wx.setStorageSync()就能存儲各種格式數(shù)據(jù),當(dāng)然也包括JSON,而不需要進行任何轉(zhuǎn)化。
比如:
//html版
var?obj?=?{
a:?123,
b:?'456'
};
localStorage.setItem('obj',obj);
console.log(localStorage.getItem('obj'));?????//?[object?Object]
localStorage.setItem('obj',JSON.stringify(obj));
console.log(localStorage.getItem('obj'));?????//?{"a":123,"b":"456"}???注:此處獲得的只是個字符串,如需轉(zhuǎn)換為JSON格式,需要使用JSON.parse()方法轉(zhuǎn)換。
//小程序版
var?obj?=?{
a:?123,
b:?'456'
};
wx.setStorageSync('obj',?obj);
console.log(wx.getStorageSync('obj'));?????//?{"a":123,"b":"456"}???注:此處獲得的是個JSON數(shù)據(jù)
二、不支持
標(biāo)簽,但標(biāo)簽支持轉(zhuǎn)義字符 “\” ,所以可以使用 “\n” 讓文字換行
可能是習(xí)慣了寫網(wǎng)頁吧,在剛開始接觸小程序開發(fā)的時候總是會習(xí)慣性地使用
標(biāo)簽來換行,后面查文檔才發(fā)現(xiàn)并沒有這個標(biāo)簽,但是可以使用 “\n” 來換行。但是需要注意的是,必須在標(biāo)簽中使用 “\n” 才能有效換行哦~~
比如:
這是第一行\(zhòng)n這是第二行
這是第一行\(zhòng)n這是第二行
三、wx.navigateTo 和 wx.redirectTo 不允許跳轉(zhuǎn)到 tabbar 頁面,只能用 wx.switchTab 跳轉(zhuǎn)到 tabbar 頁面
關(guān)于 wx.switchTab 的功能,小程序開發(fā)文檔是這樣描述的:
跳轉(zhuǎn)到 tabBar 頁面,并關(guān)閉其他所有非 tabBar 頁面
若某頁面在app.json中配置為tabBar頁面,當(dāng)從其他頁面跳轉(zhuǎn)到該頁面時必須使用 wx.switchTab
比如:
//app.json
{
"tabBar":?{
"list":?[
{
"pagePath":?"index",
"text":?"首頁"
},
{
"pagePath":?"other",
"text":?"其他"
}
]
}
}
//js
wx.switchTab({????//跳轉(zhuǎn)至index頁面
url:?'/index'
})
四、分享的頁面如果需要參數(shù)就一定要傳參,并且path要寫app.json中所配置的絕對路徑
在做小程序分享這部分的時候,一開始經(jīng)常會遇到頁面不存在的情況,后面才發(fā)覺一般遇到這種情況都是因為使用 onShareAppMessage() 方法時path沒有寫對,這時只需要將app.json中配置該頁面的路徑直接復(fù)制過來就好啦!
//?app.json
{
"pages":[
"pages/test/test"????//??①
]
}
//?test.js
onShareAppMessage:?function?()?{
return?{
title:?'自定義轉(zhuǎn)發(fā)標(biāo)題',
path:?'pages/test/test?id=123',???//此處所寫路徑與?①?處相同,若頁面需傳參數(shù),記得把參數(shù)帶上
}
}
在小程序開發(fā)過程中遇到的坑還是挺多的,在此就先分享這些了,若文中有不對的地方,請聯(lián)系安徽修補匠科技有限公司官網(wǎng) http://www.xbjtech.com