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 無法獲取,返回 0) // let verticalAccuracy = getLocationRes.verticalAccuracy; // // 水平精度,單位 m // let horizontalAccuracy = getLocationRes.horizontalAccuracy; // 4.打開地圖,選擇位置 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ì)說明", // success() { // } // }) }, }) } }) } } }) } 鏈接: http://pan.baidu.com/s/1c17eRfE 密碼: 2zwm
2.美團(tuán)菜單 1.功能僅是菜單功能一部分,僅供參考 2.需求描述:右側(cè)菜品部分在滾動(dòng)的時(shí)候,左側(cè)菜品選中分類與右側(cè)第一行菜品所在分類對(duì)應(yīng)。 我的實(shí)現(xiàn)方式:(每個(gè)菜品高度*該分類菜品數(shù)量)+菜品分類高度 = x, 每次滾動(dòng)的時(shí)候判斷當(dāng)前scrollTop是否在x范圍內(nèi)?左側(cè)選中該分類:左側(cè)不做改變; 問題:我設(shè)置菜品高度的單位是rpx,而scrollTop的單位是px,這也就是說,上面我計(jì)算的x是個(gè)變量, 所以當(dāng)改變測(cè)試機(jī)型,這個(gè)功能就失效了。。。請(qǐng)教各位有什么好的方法沒? 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)部分距離頁面頂部距離 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)于上面提到的問題2,解決方法如下,但是具體參數(shù)沒搞明白怎么回事,而且定位也不是很準(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, }) }, |
工作日 8:30-12:00 14:30-18:00
周六及部分節(jié)假日提供值班服務(wù)