微信小程序——代码片段汇集

时间:2021-11-20 22:47:17

导航栏

作者:beatzcs
       链接:https://www.jianshu.com/p/c681007a6287

这个导航虽然已经很完善了,不过还是要根据自己的来进行修改的

tabs.wxml

 <!--  顶部TabList  -->
<view wx:if="{{tab_config.fixed}}" class="tab-bar">
<view wx:for="{{tab_config.tabs}}" wx:key="unique" data-index="{{index}}" bindtap="handlerTabTap" class="tab {{tab_config.active_tab==index?'tab-active':''}} " style="width: {{tab_config.item_width}}px;">
<text>{{item}}</text>
</view>
<view style="width: {{tab_config.item_width-tab_config.underline.margins}}px; left: {{tab_config.underline.offset}}px;" class="under-line withAnimate"></view>
</view>
<scroll-view wx:else class="tab-bar" scroll-x="true" bindscroll="onScroll" style="width: 100%;" scroll-left="{{tab_config.tab_left}}">
<view wx:for="{{tab_config.tabs}}" wx:key="unique" data-index="{{index}}" bindtap="handlerTabTap" class="tab {{tab_config.active_tab==index?'tab-active':''}} " style="width: {{tab_config.item_width}}px;">
<text>{{item}}</text>
</view>
<view style="width: {{tab_config.item_width-tab_config.underline.margins}}px; left: {{tab_config.underline.offset+10}}px;" class="under-line withAnimate"></view>
</scroll-view> <!-- 滑动页面 -->
<swiper class='swiper' bindchange='bindChange' current='{{swipe_config.current}}' indicator-dots='{{swipe_config.indicator_dots}}' autoplay='{{swipe_config.autoplay}}'>
<block wx:for="{{orderList}}" wx:for-item='orders'>
<swiper-item class='swiper-item'>
<!-- 页面内容 -->
</swiper-item>
</block>
</swiper>

tabs.wxss

/*  顶部TabList  */

.withAnimate {
transition: all 200ms ease-out;
-webkit-transform: translate3d(0, 0, 0);
-moz-transform: translate3d(0, 0, 0);
-ms-transform: translate3d(0, 0, 0);
transform: translate3d(0, 0, 0);
-webkit-backface-visibility: hidden;
-moz-backface-visibility: hidden;
-ms-backface-visibility: hidden;
backface-visibility: hidden;
-webkit-perspective:;
-moz-perspective:;
-ms-perspective:;
perspective:;
} .tab-bar {
position: relative;
white-space: nowrap;
display: block;
font-size: 11pt;
color: #666;
height: 40px;
background: #fff;
} .tab-bar .tab {
display: inline-block;
line-height: 40px;
text-align: center;
} .tab-bar .tab-active {
color: #e64340;
} .tab-bar .under-line {
position: absolute;
height: 2px;
top: 38px;
background-color: #e64340;
}
.
.swiper {
  margin-top: 20rpx;
  height: 500rpx;
}

tabs.js

data: {
tabTouch: false, //tab点击会触发swiper的滚动,会导致调用两次相同的服务,使用此tag来阻止swiper调用服务,只是切换page
window_width: wx.getSystemInfoSync().windowWidth || 375,// 单位是px
tab_config: {
tabs: ['全部', '待付款', '待发货', '待收货', '已完成', '已退款', '已取消'],// tabs
fixed: false, // tabbar是否固定宽度
active_tab: 0, //当前激活的tab
item_width: 70,// 单位是px
tab_left: 0, // 如果tabbar不是固定宽度,则目前左移的位置
underline: {
offset: 0, //下划线的位移
margins: 20, //下划线的左右间距
}
},
swipe_config: {
indicator_dots: false, // 不显示小圆点
autoplay: false,// 自动切换
interval: 2000,// 自动切换频率
duration: 500, // 切换时间
current: 0 // 当前激活的panel
}
//...
}, /**
* 更换页面到指定page ,从0开始
*/
updateSelectedPage(page) {
let that = this;
//console.log("========== updateSelectedPage" + page);
let { window_width, tab_config, swipe_config } = this.data;
let underline_offset = tab_config.item_width * page; tab_config.active_tab = page;
swipe_config.current = page;
tab_config.underline.offset = underline_offset;
if (!tab_config.fixed) {
// 如果tab不是固定的 就要 检测tab是否被遮挡
let show_item_num = Math.round(window_width / tab_config.item_width); // 一个界面完整显示的tab item个数
let min_left_item = tab_config.item_width * (page - show_item_num + 1); // 最小scroll-left
let max_left_item = tab_config.item_width * page; // 最大scroll-left
if (tab_config.tab_left < min_left_item || tab_config.tab_left > max_left_item) {
// 如果被遮挡,则要移到当前元素居中位置
tab_config.tab_left = max_left_item - (window_width - tab_config.item_width) / 2;
}
}
that.setData({
"tab_config": tab_config,
"swipe_config": swipe_config
});
//调用页面的接口更新页面
that.loadOrderList(page);
}, /**
* tab的点击事件
*/
handlerTabTap(e) {
this.setData({
tabTouch: true
})
this.updateSelectedPage(e.currentTarget.dataset.index);
}, /**
* swiper的滑动事件
*/
bindChange(e) {
if (!this.data.tabTouch) {
// console.log("===== swiperChange " + e.detail.current);
this.updateSelectedPage(e.detail.current);
}
}

微信小程序——代码片段汇集的更多相关文章

  1. 微信小程序代码片段

    微信小程序代码片段是一种可分享的小项目,可用于分享小程序和小游戏的开发经验.展示组件和 API 的使用.复现开发问题等等.分享代码片段会得到一个链接,所有拥有此分享链接的人可以在工具中导入此代码片段. ...

  2. &lbrack;RN&rsqb; React Native代码转换成微信小程序代码的转换引擎工具

    React Native代码转换成微信小程序代码的转换引擎工具 https://github.com/areslabs/alita

  3. 微信小程序代码构成

    一.小程序代码 app.json 是当前小程序的全局配置,包括了小程序的所有页面路径.界面表现.网络超时时间.底部tab等. { "pages":[ "pages/ind ...

  4. 微信小程序代码大全 - 小程序开发福利

    小程序QQ交流群:131894955 小程序开发文档(Wepy) 小程序商城源码下载(weixin-app-shop) 小程序官网源码下载(weixin-app-cms) 微信管家平台JAVA版开源下 ...

  5. webstorm开发微信小程序代码提醒&lpar;webstorm开发工具&rpar;

    使用了微信提供的开发工具是真心难用,卡顿厉害.中英文切写注释换相当不爽.还没办法多开窗口,相信大家也遇到过这种现象. 下边我们介绍下webstorm来开发微信小程序的一些配置: File---sett ...

  6. 微信小程序代码开源啦

    想学习如何使用mpvue开发微信小程序吗? 想知道微信消息推送如何实现吗? 想知道如何用springboot开发小程序后台吗? 看这里就全都有了.耗时一个月打造的微信小程序:PSN折扣助手前后端所有源 ...

  7. 史上最全的微信小程序代码大全

    --------------------- 本文来自 fenxiangjun 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/fenxiangjun/article/d ...

  8. 如何减小微信小程序代码包大小

    原作于:https://captnotes.com/how_to_reduce_package_size_of_weapp 这两天被小程序代码包大小暴涨的问题困扰了挺久.简单说说怎么回事吧,就是之前好 ...

  9. 微信小程序--代码构成---JSON 配置

    在上一章中,我们通过开发者工具快速创建了一个 QuickStart 项目.你可以留意到这个项目里边生成了不同类型的文件: .json 后缀的 JSON 配置文件 .wxml 后缀的 WXML 模板文件 ...

随机推荐

  1. python 2&period;43 升级到2&period;7

    [root@GW1 bin]# lsb_release -aLSB Version: :core-3.1-amd64:core-3.1-ia32:core-3.1-noarch:graphics-3. ...

  2. 7 -- Spring的基本用法 -- 3&period;&period;&period;

    7.3 Spring 的核心机制 : 依赖注入 Spring 框架的核心功能有两个. Spring容器作为超级大工厂,负责创建.管理所有的Java对象,这些Java对象被称为Bean. Spring容 ...

  3. 黄聪:走进wordpress 详细说说template-loader&period;php

    再看template-laoder.php,这个文件总共只有45行.它的作用是基于访问的URL装载正确的模板. 文件第六行,也是第一条语句,如下: if ( defined('WP_USE_THEME ...

  4. QTimerLine类学习

      QTimeLine类提供了控制动画的时间轴. 类型:enum CurveShape{EaseInCurve,EaseOutCurve,EaseInOutCurve,LinearCurve,Sine ...

  5. iOS 开源库

    youtube下载神器:https://github.com/rg3/youtube-dl我擦咧 vim插件:https://github.com/Valloric/YouCompleteMevim插 ...

  6. Python 串口通信操作

    下载  pyserial包 https://pypi.python.org/packages/source/p/pyserial/pyserial-2.7.tar.gz#md5=794506184df ...

  7. python调用百度语音(语音识别-斗地主语音记牌器)

    一.概述 本篇简要介绍百度语音语音识别的基本使用(其实是斗地主时想弄个记牌器又没money,抓包什么的又不会,只好搞语音识别的了) 二.创建应用 打开百度语音官网,产品与使用->语音识别-&gt ...

  8. 基于event 实现的线程安全的优先队列&lpar;python实现&rpar;

    event 事件是个很不错的线程同步,以及线程通信的机制,在python的许多源代码中都基于event实现了很多的线程安全,支持并发,线程通信的库 对于优先队列的堆实现,请看<python下实现 ...

  9. python webdriver api-上传文件的三种方法

    上传文件: 第一种方式,sendkeys(),最简单的 #encoding=utf-8 from selenium import webdriver import unittest import ti ...

  10. P3374 【模板】树状数组 1(cdq)

    P3374 [模板]树状数组 1 cdq分治 刚学了cdq分治(dyf神犇强力安利下),发现可以做这种题,当然是来试水了(逃 cdq好像只能离线的样子 cdq分治(转) 以下是摘录的几句: 在合并的时 ...