小程序模板網(wǎng)

微信小程序---美團(tuán)頂部搜索框&菜單

發(fā)布時(shí)間:2018-04-21 09:02 所屬欄目:小程序開發(fā)教程

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,
    })
  },


易優(yōu)小程序(企業(yè)版)+靈活api+前后代碼開源 碼云倉庫:starfork
本文地址:http://22321a.com/wxmini/doc/course/23824.html 復(fù)制鏈接 如需定制請(qǐng)聯(lián)系易優(yōu)客服咨詢:800182392 點(diǎn)擊咨詢
QQ在線咨詢