| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 | <template>  <view class="container">    <view class="backHeader">      <image        @click="handleBack"        class="backIcon"        src="@/static/index/convenient-services/return.png"      ></image>      <text class="pageTitle">充值商家</text>    </view>    <view class="checkoutMerchant">        <div class="tabsNavs">            <view class="tab-item" @click="changeTab(index)" :class="{active : currentIndex == index}" v-for="(item, index) in tabs" :key="item">                {{ item }}            </view>            <div class="tab-active" :style="{width: 750/tabs.length + 'rpx', left: currentIndex * 750/tabs.length - 20 + 'rpx'}"></div>        </div>    </view>    <view class="merchantList">        <keep-alive>            <merchantList ref="merchantList" v-if="currentIndex == 0"></merchantList>            <historyMerchantList ref="historyMerchantList" v-if="currentIndex == 1"></historyMerchantList>        </keep-alive>    </view>  </view></template><script>import historyMerchantList from './components/historyMerchantList.vue'import merchantList from './components/merchantList.vue'export default {  name: "selectMerchant",  components: {    historyMerchantList,    merchantList  },  data() {    return {        tabs: ['商家列表','我的商家'],        currentIndex: 0,    };  },  methods: {    handleBack() {        uni.navigateBack();    },    changeTab(index){        this.currentIndex = index    }  },  onReachBottom() {        let arr = [this.$refs.merchantList, this.$refs.historyMerchantList]        arr[this.currentIndex].getMoreList()  }};</script><style lang="scss">.container {    background-color: #F8F9FB;    .backHeader {        position: relative;        width: 750rpx;        height: 88rpx;        /* background-color: #fff; */        display: flex;        align-items: center;        .backIcon {            width: 60rpx;            height: 60rpx;        }        .pageTitle {            font-family: 思源黑体;            font-size: 32rpx;            font-weight: 600;            line-height: 44rpx;            letter-spacing: 0.32rpx;            color: #222229;            position: absolute;            left: 50%;            transform: translateX(-50%);        }    }    .checkoutMerchant {        width: 100vw;        box-sizing: border-box;        padding: 32rpx;        display: flex;          .tabsNavs {                position: relative;                display: flex;                justify-content: flex-start;                align-items: center;                overflow: hidden;                width: 100%;                height: 76rpx;                border-bottom: 2rpx solid #F5F5F5;                border-radius: 50rpx;                box-shadow: 0px 2rpx 6rpx 0px rgba(9, 23, 49, 0.21);                 .tab-item {                    z-index: 2;                    display: flex;                    justify-content: center;                    align-items: center;                    flex: 1;                    /* height: 100%;                    width: 180rpx; */                    color: #888889;                    padding: 0 10rpx;                }                .active {                    color: #FFFFFF;                    transition: color .4s; /* 针对 color 来实现动画 */                }                .tab-active {                    z-index: 1;                    position: absolute;                    bottom: 0;                    /* width: 110px; */                    height: 100%;                    display: inline-block;                    border-radius: 50rpx;                    background: #EF530E;                    transition: left .4s; /* 针对 left 变动来实现动画 */                }            }    }    .merchantList {        width: 100vw;        box-sizing: border-box;        padding: 32rpx;    }}</style>
 |