小程序自定义索引菜单

本文实例为大家分享了小程序自定义索引菜单的具体代码,供大家参考,具体内容如下

<view class="indexes_chunk" wx:for="{{brandIndexList.brandGroupList}}" wx:key="item">
     <view class="letter ancehor-{{item.indexLetter}}">{{item.indexLetter}}</view>
     <view class="choice" wx:for="{{item.brandList}}" wx:for-item="items" wx:key="items" wx:for-index="cindex">
          <text class="text actives">{{items.enName}}{{items.cnName}}</text>
          <text class="iconfont icon-gouxuan"></text>
   </view>
</view>

主要代码:

function throttle(fn, interval) {
    var enterTime = 0;//触发的时间
    var gapTime = interval || 300 ;//间隔时间,如果interval不传,则默认300ms
    return function() {
      var context = this;
      var backTime = new Date();//第一次函数return即触发的时间
      if (backTime - enterTime > gapTime) {
        fn.call(context,arguments);
        enterTime = backTime;//赋值给第一次触发的时间,这样就保存了第二次触发的时间
      }
    };
};
data:{
      brandIndexList:{
            brandGroupList:[
                {
                    brandList:[
                        {brandId:1, cnName: "爱马仕A", enName: "Hermes", indexLetter: "A"}
                    ],
                    indexLetter: "A"
                },
                {
                    brandList:[
                        {brandId:2, cnName: "爱马仕B", enName: "Hermesss", indexLetter: "B"}
                    ],
                    indexLetter: "B"
                },
                {
                    brandList:[
                        {brandId:3, cnName: "爱马仕G", enName: "Hermes", indexLetter: "G"}
                    ],
                    indexLetter: "G"
                },
                {
                    brandList:[
                        {brandId:4, cnName: "爱马仕M", enName: "Hermesss", indexLetter: "M"}
                    ],
                    indexLetter: "M"
                },
                {
                    brandList:[
                        {brandId:5, cnName: "爱马仕P", enName: "Hermesss", indexLetter: "P"}
                    ],
                    indexLetter: "P"
                },
                {
                    brandList:[
                        {brandId:6, cnName: "爱马仕V", enName: "Hermesss", indexLetter: "V"}
                    ],
                    indexLetter: "V"
                }
            ],
            indexLetterList: ["A", "B", "G", "M", "P", "V"]
        },
   letterNodes:[],//索引菜单 全部节点位置
   letterIndex:0,
}

  onReady(){
     
        let self = this;
        let indexLetterList = self.data.brandIndexList.indexLetterList,
            letterNodes = self.data.letterNodes,
            nodes = '.ancehor-',
            arrs = [];
            // 获取所有索引锚点节点
            indexLetterList.forEach((item)=>{
                arrs.push(nodes+item);
                if(arrs.length == indexLetterList.length){
                    self.getDoms(arrs.join(','),(res)=>{
                        letterNodes = res.map((item)=>{return item.top-88});
                        self.setData({
                            letterNodes:letterNodes
                        });
                    });
                    wx.hideLoading();
                }
            });
    },
    // 动态获取节点
     getDoms(node,success){
        let self = this,
            query = wx.createSelectorQuery();
            setTimeout(()=>{
                query.selectAll(node).boundingClientRect((res)=>{
                    success && success(res);
                }).exec()
            },1000);
    },
     // 索引菜单点击滚动
    letterClick(e){
        let self = this,
            index = e.currentTarget.dataset.index,
            letterNodes = self.data.letterNodes;

            wx.pageScrollTo({
                scrollTop: letterNodes[index]
            })
    },
     // 页面滚动
    onPageScroll:throttle(function(e){
     let self = this,
         scrollTop = e[0].scrollTop,
         stickyTop = self.data.stickyTop,
         letterNodes = self.data.letterNodes,
         showSticky = self.data.showSticky,
         letterIndex = self.data.letterIndex;
        // 显示右侧索引
        if(scrollTop>=stickyTop){
            showSticky = true;
        }else{
            showSticky = false;
        }
        //滚动定位索引
        letterNodes.forEach((item,index)=>{
            if(scrollTop>=item){
                letterIndex = index;
                // console.log(index)
            }
        })
      
        // console.log(scrollTop)
        self.setData({
            showSticky:showSticky,
            letterIndex:letterIndex
        });
    },10)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 微信小程序实现字母索引菜单

    本文实例为大家分享了微信小程序实现字母索引菜单的具体代码,供大家参考,具体内容如下 wxml文件 <view class="container"> <view class="content">   <view class="all-food">     <view class="food">全部食物</view>       <scroll-view class

  • 微信小程序实现全国机场索引列表

    本文为大家分享了微信小程序实现MUI索引列表的具体代码,供大家参考,具体内容如下 效果展示图 实现的原理 '当前选择机场'和右侧的导航栏采用的是固定定位: 左侧的展示窗口的滚动采用的是scroll-view组件: 选择中的字母提示是自己WXSS样式制作. WXML <view class="right-nav"> <view bindtap="getCurrentCode" class="{{chooseIndex == index ?

  • 小程序自定义索引菜单

    本文实例为大家分享了小程序自定义索引菜单的具体代码,供大家参考,具体内容如下 <view class="indexes_chunk" wx:for="{{brandIndexList.brandGroupList}}" wx:key="item">      <view class="letter ancehor-{{item.indexLetter}}">{{item.indexLetter}}<

  • 微信小程序自定义菜单切换栏tabbar组件代码实例

    这篇文章主要介绍了微信小程序自定义菜单切换栏tabbar组件代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 效果图: wxml代码: <view class="top_tabbar" > <block wx:for="{{itemName}}" wx:key="{{index}}"> <view class="item_name {{tabInde

  • 微信小程序自定义菜单导航实现楼梯效果

    设计初衷 在开发页面时,往往需要实现,点击页面的导航菜单页面滚动到相应位置,滚动页面实现菜单选项的高亮.在html开发中,我们可以用到a标签锚点实现,jq的动画相结合实现类似效果.在框架中vant UI框架也为我们实现了这一效果. 微信小程序该如何实现?? 效果展示 当菜单导航滚动到页面顶部时,菜单吸顶 当点击菜单按钮时,切换到对应区域(过渡到该区域,有动画效果) 当内容区滚动到某类区域时,对应区域的菜单按钮高亮 设计思路 1.吸顶效果的实现 获取菜单导航距离页面顶部距离wx.createSel

  • 微信小程序自定义tabBar的踩坑实践记录

    微信官方文档对自定义 tabBar 的阐述较为潦草,在开发自定义 tabBar 过程中我踩了很多坑,因此在此处做个总结. 我使用 Vant Weapp作为 UI 组件库,下面以此组件库为例. 定义 tabBar 创建自定义 tabBar 文件 创建一个与 /pages 的同级目录,命名为  /custom-tab-bar,注意目录层级与目录命名问题,不可用其他名称命名. 在 /custom-tab-bar 下创建四个文件: index.js index.json index.wxml index

  • 微信小程序自定义可滑动顶部TabBar选项卡实现页面切换功能示例

    本文实例讲述了微信小程序自定义可滑动顶部TabBar选项卡实现页面切换功能.分享给大家供大家参考,具体如下: 顶部滚动选项卡 话不多说,直接上代码 pages/home/home.wxml <scroll-view scroll-x="true" style='width: 100%; white-space:nowrap; '> <!-- tab --> <view class="tab"> <view class=&qu

  • 微信小程序自定义select下拉选项框组件的实现代码

    知识点:组件,animation,获取当前点击元素的索引与内容 微信小程序中没有select下拉选项框,所以只有自定义.自定义的话,可以选择模板的方式,也可以选择组件的方式来创建. 这次我选择了组件,这样只需引入组件和添加数据,其它的不用管,就能实现多个地方重复使用了. 第一步:创建组件所需的文件 我喜欢把共用的内容都放在和pages文件同级的地方,所以有了下面的目录结构 (1) 先创建一个自定义名字的文件夹,例如我上面的Componet (2) 再创建一个select文件夹,然后:右键这个文件

  • 小程序自定义导航栏兼容适配所有机型(附完整案例)

    前言 大部分情况下我们都是使用微信官方自带的 navigationBar 配置 ,但有时候我们需要在导航栏集成搜索框.自定义背景图.返回首页按钮等. 思路 隐藏官方导航栏 获取胶囊按钮.状态栏相关数据以供后续计算 根据不同机型计算导航栏高度 编写新的导航栏 页面引用自定义导航 正文 隐藏官方导航栏 隐藏导航栏可以全局配置,也可以单独页面配置,具体根据业务需求来. 全局隐藏 //app.json "window": { "navigationStyle": "

  • 微信小程序自定义顶部组件customHeader的示例代码

    1.开启配置自定义顶部 { "window": { "navigationStyle":"custom" } } 在app.json的文件window配置"navigationStyle": "custom"属性即可 2.自定义顶部计算原理 2.1 获取系统状态栏的高度和屏幕宽度 使用wx.getSystemInfo这个函数获取系统状态栏的高度和屏幕宽度. 2.2 获取右上角胶囊位置信息 使用wx.getM

  • 微信小程序自定义yPicker组件实现省市区三级联动功能

    自从上一篇文章:微信小程序自定义日历组件及flex布局最后一行对齐问题分析 出来以后,有人私聊我说能不能从头分析一下我开源的自定义组件?一直没时间.这不,最近项目中有个需求是 省市区三级联动 ,我就顺便从组件库中的第一个 「扩展日期-时间picker(点此直接至GitHub,欢迎star)」组件开始说一下这两个功能的实现. 简单说一下"自定义日期-时间组件" 它的背景是项目的第一版当时发现微信小程序内置的日期组件:picker只能精确到某一天(年月日),但是我们很多时候需要年月日时分甚

  • 微信小程序自定义可搜索的picker组件示例详解

    PC端开发,组件库是有可搜索的select可用 但是在手机端微信小程序开发的时候,使用select就不太合适了,小程序端的选项一般都是是使用picker 但是,问题又来了,微信小程序官方并没有给我们提供可搜索的Picker 人家没给,那我们就自定义一个呗 别的到没啥,就是感觉交互上有点奇怪 具体效果如下图所示: 废话不多说了,上代码: myPicker.wxml <view class="date-background" hidden="{{flag}}"&g

随机推荐