Rumah  >  Artikel  >  applet WeChat  >  Perbincangan ringkas tentang cara untuk mencapai kesan pautan ke atas dan ke bawah tatal senarai dalam program kecil

Perbincangan ringkas tentang cara untuk mencapai kesan pautan ke atas dan ke bawah tatal senarai dalam program kecil

青灯夜游
青灯夜游ke hadapan
2021-12-16 10:30:243465semak imbas

Bagaimanakah program mini boleh mencapai kesan menatal ke atas dan ke bawah senarai? Artikel berikut akan memperkenalkan kepada anda kaedah membangunkan applet WeChat untuk menatal ke atas dan ke bawah senarai saya harap ia akan membantu anda!

Perbincangan ringkas tentang cara untuk mencapai kesan pautan ke atas dan ke bawah tatal senarai dalam program kecil

1 Latar Belakang

Saya sedang mengusahakan program kecil untuk syarikat, dan salah satu reka bentuk adalah untuk menatal ke atas dan ke bawah senarai. Pada masa ini, bar tab di bahagian atas akan dipautkan bersama Apabila bar tab diklik, data senarai juga akan dipautkan.

Berikut ialah pemaparan pelaksanaan:

Perbincangan ringkas tentang cara untuk mencapai kesan pautan ke atas dan ke bawah tatal senarai dalam program kecil

Kawasan pengepala di bahagian atas tidak menatal dengan senarai; Kawasan di bawah kawasan kepala tergolong dalam kawasan skrol.

2. Pelaksanaan

2.1 Pengenalan prinsip

Pelaksanaan tempat ini bergantung terutamanya pada komponen scroll-view asli applet WeChat.

Gunakan atribut tatal ke dalam paparannya untuk mengklik pada bar tab di bahagian atas untuk menatal halaman ke kedudukan senarai yang ditentukan

Gunakan acara bindscroll untuk mengetahui jarak tatal halaman semasa , lakukan operasi penukaran bar tab berdasarkan jarak tatal; kawasan kepala tetap dan kawasan senarai boleh tatal .

Apabila bar tajuk bagi kawasan senarai boleh tatal ditatal pada jarak tertentu, bar itu juga harus ditetapkan di bahagian atas.

Pelaksanaan kod:

Terdapat beberapa perkara yang perlu diperhatikan dalam kod reka letak:

1 Pengiraan ketinggian kawasan skrol. --- Dapatkan ketinggian tetingkap peranti semasa tolak ketinggian kawasan tetap atas
<!--index.wxml-->
<view class="list">

<!--顶部固定区域-->
<view style="height: 88rpx;width: 100%;background-color: burlywood;text-align: center;">头部区域</view>

<!--可滚动区域-->
<scroll-view scroll-y="true" style="width: 100%; height: {{scrollAreaHeight}}px;" bindscroll="scroll" scroll-into-view="{{scrollToItem}}" scroll-with-animation="true"  scroll-top="{{scrollTop}}">

   <!--水平滚动的tab栏-->
  <scroll-view scroll-x="true" style="height: 88rpx;width: 100%;">
  <view class="head-area {{float ? &#39;head-float&#39; : &#39;&#39;}}" >
    <view class="head-area-item {{curSelectTab === index ? &#39;head-area-item-select&#39; : &#39;&#39;}}" wx:for="{{appGroupList}}" bindtap="tabClick" data-index="{{index}}">
    {{item.name}}
  </view>
  </view>

  </scroll-view>

<!--数据列表-->
<view class="list-group" style="height: {{listGroupHeight}}px;">
  <view class="list-group-item" id="v_{{index}}" wx:for="{{appGroupList}}" data-index="{{index}}">
    <view class="group-name">
      {{item.name}}
    </view>
    <view class="group-children" >
      <view wx:for="{{item.children}}" class="group-children-item" style="width: {{itemWidth}}px;">
      <image src="{{item.url}}"></image>
      <view>{{item.name}}</view>
    </view>
    </view>

  </view>
</view> 
</scroll-view>

</view>

2. Sama ada bar tab mendatar berada di atas. --- Berdasarkan jarak tatal halaman, jika jarak tatal lebih besar daripada atau sama dengan ketinggian bar tab mendatar, ia akan dialihkan ke atas

3 ="v_{{index}}" id senarai data, Klik seterusnya pada bar tab untuk menatal ke kedudukan yang ditentukan dilaksanakan berdasarkan ID ini.

2.2 Kod gaya

2.3 Kod logik

/**index.wxss**/
.list{
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.head-area{
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  height: 88rpx;
  width: 100%;
  padding: 0 10;
}

.head-area-item{
  display: flex;
  height: 88rpx;
  text-align: center;
  width: 150rpx;
  align-items: center;
  justify-content: center;
}

.head-area-item-select{
  color: #09bb07;
}

image{
  width: 88rpx;
  height: 88rpx;
}

.list-group{
  display: flex;
  width: 100%;
  height: 1000%;
  flex-direction: column;
}

.list-group-item{
  display: flex;
  width: 100%;
  background-color: #aaa;
  flex-direction: column;
}

.group-name{
  height: 88rpx;
  display: flex;
  text-align: center;
  align-items: center;
  margin-left: 20rpx;
}

.group-children{
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  width: 100%;
}

.group-children-item{
  height: 160rpx;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.head-float{
  position: fixed;
  top: 88rpx;
  background-color: #ffffff;
}
Terdapat dua tempat utama dalam kod logik:

1 tatasusunan ketinggian item dalam senarai dan menyimpan hasil pengiraan akhir dalam tatasusunan heightArr.
// index.js
Page({
  heightArr: [],
  //记录scroll-view滚动过程中距离顶部的高度
  distance: 0,
  data: {
    appGroupList:[
      {name:"分组01",children:[{"name":"测试0","url":"/images/bluetooth.png"},
      {"name":"测试1","url":"/images/bluetooth.png"},
      {"name":"测试2","url":"/images/bluetooth.png"},
      {"name":"测试3","url":"/images/bluetooth.png"},
      {"name":"测试4","url":"/images/bluetooth.png"},
      {"name":"测试5","url":"/images/bluetooth.png"},
      {"name":"测试6","url":"/images/bluetooth.png"},
      {"name":"测试7","url":"/images/bluetooth.png"}]},
      {name:"分组02",children:[{"name":"测试0","url":"/images/bluetooth.png"},
      {"name":"测试1","url":"/images/bluetooth.png"},
      {"name":"测试2","url":"/images/bluetooth.png"},
      {"name":"测试3","url":"/images/bluetooth.png"},
      {"name":"测试4","url":"/images/bluetooth.png"},
      {"name":"测试5","url":"/images/bluetooth.png"},
      {"name":"测试6","url":"/images/bluetooth.png"},
      {"name":"测试7","url":"/images/bluetooth.png"}]},
      {name:"分组03",children:[{"name":"测试0","url":"/images/bluetooth.png"},
      {"name":"测试1","url":"/images/bluetooth.png"},
      {"name":"测试2","url":"/images/bluetooth.png"},
      {"name":"测试3","url":"/images/bluetooth.png"},
      {"name":"测试4","url":"/images/bluetooth.png"},
      {"name":"测试5","url":"/images/bluetooth.png"},
      {"name":"测试6","url":"/images/bluetooth.png"},
      {"name":"测试7","url":"/images/bluetooth.png"}]},
      {name:"分组04",children:[{"name":"测试0","url":"/images/bluetooth.png"},
      {"name":"测试1","url":"/images/bluetooth.png"},
      {"name":"测试2","url":"/images/bluetooth.png"},
      {"name":"测试3","url":"/images/bluetooth.png"},
      {"name":"测试4","url":"/images/bluetooth.png"},
      {"name":"测试5","url":"/images/bluetooth.png"},
      {"name":"测试6","url":"/images/bluetooth.png"},
      {"name":"测试7","url":"/images/bluetooth.png"}]},
      {name:"分组05",children:[{"name":"测试0","url":"/images/bluetooth.png"},
      {"name":"测试1","url":"/images/bluetooth.png"},
      {"name":"测试2","url":"/images/bluetooth.png"},
      {"name":"测试3","url":"/images/bluetooth.png"},
      {"name":"测试4","url":"/images/bluetooth.png"},
      {"name":"测试5","url":"/images/bluetooth.png"},
      {"name":"测试6","url":"/images/bluetooth.png"},
      {"name":"测试7","url":"/images/bluetooth.png"}]},
    ],
    itemWidth: wx.getSystemInfoSync().windowWidth / 4,
    scrollAreaHeight:wx.getSystemInfoSync().windowHeight - 44,
    float:false,
    curSelectTab:0,
    scrollToItem:null,
    scrollTop: 0, //到顶部的距离
    listGroupHeight:0,
  },

  onReady: function () {
    this.cacluItemHeight();
  },

  scroll:function(e){
    console.log("scroll:",e);
    if(e.detail.scrollTop>=44){
      this.setData({
        float : true
      })
    } else if(e.detail.scrollTop<44) {
      this.setData({
        float : false
      })
    }
    let scrollTop = e.detail.scrollTop;
    let current = this.data.curSelectTab;
    if (scrollTop >= this.distance) {
      //页面向上滑动
      //列表当前可视区域最底部到顶部的距离 超过 当前列表选中项距顶部的高度(且没有下标越界),则更新tab栏
      if (current + 1 < this.heightArr.length && scrollTop >= this.heightArr[current]) {
        this.setData({
          curSelectTab: current + 1
        })
      }
    } else { 
      //页面向下滑动
      //如果列表当前可视区域最顶部到顶部的距离 小于 当前列表选中的项距顶部的高度,则切换tab栏的选中项
      if (current - 1 >= 0 && scrollTop < this.heightArr[current - 1]) {
        this.setData({
          curSelectTab: current - 1
        })
      }
    }
    //更新到顶部的距离
    this.distance = scrollTop;
  },

  tabClick(e){
    this.setData({
      curSelectTab: e.currentTarget.dataset.index,
      scrollToItem: "v_"+e.currentTarget.dataset.index
    })
  },

  //计算每一个item高度
  cacluItemHeight() {
    let that = this;
    this.heightArr = [];
    let h = 0;
    const query = wx.createSelectorQuery();
    query.selectAll(&#39;.list-group-item&#39;).boundingClientRect()
    query.exec(function(res) {
      res[0].forEach((item) => {
        h += item.height;
        that.heightArr.push(h);
      })
      console.log(that.heightArr);
      that.setData({
        listGroupHeight: that.heightArr[that.heightArr.length - 1 ]
      })
    })
  },
})

Nilai setiap item dalam tatasusunan heightArr terkumpul berdasarkan item sebelumnya.

2 Tentukan arah tatal semasa dalam tatal, tentukan arah semasa berdasarkan tatal, dan kemudian tetapkan tab yang dipilih berdasarkan jarak tatal.

Baiklah, itu sahaja Berdasarkan kandungan di atas, anda pada asasnya boleh mencapai pautan tatal dan kesan pautan tab.

[Cadangan pembelajaran berkaitan:

Tutorial Pembangunan Program Mini

]

Atas ialah kandungan terperinci Perbincangan ringkas tentang cara untuk mencapai kesan pautan ke atas dan ke bawah tatal senarai dalam program kecil. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:juejin.cn. Jika ada pelanggaran, sila hubungi admin@php.cn Padam