?
vant weapp的Area省市區(qū)選擇業(yè)務(wù)組件提供了一個(gè)云開發(fā)示例但是沒(méi)寫詳細(xì)的過(guò)程,這里把具體步驟說(shuō)明一下。方便一下別的同學(xué)。
Vant Weapp組件的說(shuō)明
省市區(qū)選擇組件(https://youzan.github.io/vant-weapp/#/area)
實(shí)際項(xiàng)目中,可以通過(guò)小程序云開發(fā)的能力,將省市區(qū)數(shù)據(jù)保存在云開發(fā)的數(shù)據(jù)庫(kù)中,并在小程序中使用云開發(fā)的接口異步獲取數(shù)據(jù)。
在小程序中使用云能力之前需要先調(diào)用wx.could.init方法完成云能力的初始化。
實(shí)現(xiàn)方法
省市區(qū)數(shù)據(jù)獲取
vant的說(shuō)明:
整體是一個(gè) Object,包含 provincelist, citylist, county_list 三個(gè) key。
每項(xiàng)以省市區(qū)編碼作為 key,省市區(qū)名字作為 value。編碼為 6 位數(shù)字,前兩位代表省份,中間兩位代表城市,后兩位代表區(qū)縣,以 0 補(bǔ)足 6 位。如北京編碼為 11,以零補(bǔ)足 6 位,為 110000。
1.根據(jù)說(shuō)明我們要先找到完整數(shù)據(jù)(https://github.com/youzan/vant/blob/dev/src/area/demo/area.js)
2.復(fù)制完整數(shù)據(jù)area.js中 export default 對(duì)象的內(nèi)容(即export default后面所有內(nèi)容,包含花括號(hào))
3.本地新建一個(gè)area.json文件,將上述復(fù)制內(nèi)容粘貼進(jìn)去并保存
數(shù)據(jù)導(dǎo)入云開發(fā)數(shù)據(jù)庫(kù)
1.打開云開發(fā)的管理控制臺(tái),點(diǎn)擊數(shù)據(jù)庫(kù)按鈕切換至數(shù)據(jù)庫(kù)管理界面
2.點(diǎn)擊界面左側(cè)的加號(hào)新建集合,輸入集合名稱(例:area)
3.導(dǎo)入獲取到的省市區(qū)數(shù)據(jù)area.json文件,導(dǎo)入成功后即可看到集合中多了一條記錄
小程序中使用
1.wx.could.init方法完成云能力的初始化
使用mpvue時(shí)只需要在src/main.js中添加實(shí)例化代碼就可以
-
wx.cloud.init({
-
traceUser: true
-
})
2.具體頁(yè)面中調(diào)用獲取數(shù)據(jù)的接口
本示例是在彈層中顯示省市區(qū)(已引入popup及area組件)
vue頁(yè)面
-
<van-popup :show="show" position="bottom" custom-style="height: 40%;">
-
<van-area
-
:area-list="areaList"
-
:value="area"
-
@confirm="chooseAddress"
-
@cancel="cancelChoose"
-
columns-placeholder="['請(qǐng)選擇', '請(qǐng)選擇', '請(qǐng)選擇']"
-
/>
-
</van-popup>
頁(yè)面data
-
data() {
-
return {
-
...
-
areaList: [],
-
area: ''
-
...
-
}
-
},
頁(yè)面onLoad/onShow鉤子中加入代碼
-
onLoad() {
-
const db = wx.cloud.database()
-
db.collection('area').get()
-
.then(res => {
-
if (res.data && res.data.length > 0) {
-
delete (res.data[0]._id)
-
this.areaList = res.data[0]
-
}
-
this.init()
-
})
-
.catch(err => {
-
console.log(err)
-
})
-
},
-
?
-
//點(diǎn)擊確定時(shí)的方法
-
chooseAddress({ mp }) {
-
let ads = mp.detail.values
-
this.province = ads[0].code
-
this.city = ads[1].code
-
this.district = ads[2].code
-
this.address = ads[0].name + ads[1].name + ads[2].name
-
this.show = false
-
},
效果示例
省市區(qū)彈層
Network請(qǐng)求
?
?
本文摘自 :https://blog.51cto.com/x