|
1.美團(tuán)頂部搜索框
// 定位
toNearby: function () {
var that = this
// 1.查看接口是否可用
wx.getSetting({
success(res) {
if (!res['userLocation']) {
// 2.如果接口不能調(diào)用,請(qǐng)求調(diào)用
wx.authorize({
scope: 'scope.userInfo',
success(authorizeRes) {
// 3.獲取當(dāng)前的地理位置、速度
wx.getLocation({
type: 'wgs84',
success: function (getLocationRes) {
// // 緯度,浮點(diǎn)數(shù),范圍為-90~90,負(fù)數(shù)表示南緯
// let latitude = getLocationRes.latitude;
// // 經(jīng)度,浮點(diǎn)數(shù),范圍為-180~180,負(fù)數(shù)表示西經(jīng)
// let longitude = getLocationRes.longitude;
// // 速度,浮點(diǎn)數(shù),單位m/s
// let speed = getLocationRes.speed;
// // 位置的精確度
// let accuracy = getLocationRes.accuracy;
// // 高度,單位 m
// let altitude = getLocationRes.altitude;
// // 垂直精度,單位 m(Android 無(wú)法獲取,返回 0)
// let verticalAccuracy = getLocationRes.verticalAccuracy;
// // 水平精度,單位 m
// let horizontalAccuracy = getLocationRes.horizontalAccuracy;
// 4.打開(kāi)地圖,選擇位置
wx.chooseLocation({
success(chooseLocationRes) {
// 位置名稱
let name = chooseLocationRes.name;
// 詳細(xì)地址
let address = chooseLocationRes.address;
// 緯度
let latitude = chooseLocationRes.latitude;
// 經(jīng)度
let longitude = chooseLocationRes.longitude;
that.setData({ address: name })
},
// 用戶取消時(shí)調(diào)用
cancel() {
console.log("用戶取消調(diào)用")
}
})
// 5.使用微信內(nèi)置地圖查看位置
// wx.openLocation({
// // 緯度,范圍為-90~90,負(fù)數(shù)表示南緯
// latitude: getLocationRes.latitude,
// // 經(jīng)度,范圍為-180~180,負(fù)數(shù)表示西經(jīng)
// longitude: getLocationRes.longitude,
// // 縮放比例,范圍5~18,默認(rèn)為18
// scale: 18,
// name: "位置名",
// address: "地址的詳細(xì)說(shuō)明",
// success() {
// }
// })
},
})
}
})
}
}
})
}
鏈接: http://pan.baidu.com/s/1c17eRfE 密碼: 2zwm
2.美團(tuán)菜單 1.功能僅是菜單功能一部分,僅供參考 2.需求描述:右側(cè)菜品部分在滾動(dòng)的時(shí)候,左側(cè)菜品選中分類(lèi)與右側(cè)第一行菜品所在分類(lèi)對(duì)應(yīng)。 我的實(shí)現(xiàn)方式:(每個(gè)菜品高度*該分類(lèi)菜品數(shù)量)+菜品分類(lèi)高度 = x, 每次滾動(dòng)的時(shí)候判斷當(dāng)前scrollTop是否在x范圍內(nèi)?左側(cè)選中該分類(lèi):左側(cè)不做改變; 問(wèn)題:我設(shè)置菜品高度的單位是rpx,而scrollTop的單位是px,這也就是說(shuō),上面我計(jì)算的x是個(gè)變量, 所以當(dāng)改變測(cè)試機(jī)型,這個(gè)功能就失效了。。。請(qǐng)教各位有什么好的方法沒(méi)?
onLoad(e) {
let goodsList = this.data.goodsList;
// 初始化每項(xiàng)菜品距離頂部的距離
for (let i = 0; i < goodsList.length; i++) {
if (i != 0)
goodsList[i].scrollTop = parseInt(goodsList[i - 1].scrollTop) + parseInt((goodsList[i - 1].goods.length * 90) + 35)
}
this.data.goodsList = goodsList;
},
// 右側(cè)滾動(dòng)事件
onGoodsScroll: function (e) {
let that = this;
// 當(dāng)前滾動(dòng)部分距離頁(yè)面頂部距離
let scrollTop = parseInt(e.detail.scrollTop);
let goodsList = that.data.goodsList;
for (let i = 0; i < goodsList.length; i++) {
let currentScrollTop = goodsList[i].scrollTop;
let nextScrollTop = 0;
if ((i + 1) == goodsList.length)
nextScrollTop = goodsList[i].scrollTop;
else
nextScrollTop = goodsList[i + 1].scrollTop;
if (currentScrollTop < scrollTop && scrollTop < nextScrollTop) {
that.setData({
classifyIdLeft: goodsList[i].id,
classifySeleted: goodsList[i].id
})
}
}
}
Demo鏈接: http://pan.baidu.com/s/1pLhWlh5 密碼: 1gk6 關(guān)于上面提到的問(wèn)題2,解決方法如下,但是具體參數(shù)沒(méi)搞明白怎么回事,而且定位也不是很準(zhǔn),請(qǐng)求各位有什么好方法
// 右側(cè)滾動(dòng)事件
onGoodsScroll: function (e) {
let that = this;
let scale = e.detail.scrollWidth / 600;
let scrollTop = e.detail.scrollTop / scale;
let h = 0;
let classifySeleted;
let len = that.data.goodsList.length;
that.data.goodsList.forEach(function (classify, i) {
var _h = 70 + classify.goods.length * 180;
if (scrollTop >= h - 100 / scale) {
classifySeleted = classify.id;
}
h += _h;
});
that.setData({
classifySeleted: classifySeleted,
classifyIdLeft: classifySeleted,
})
},
|