vue外卖十六:商家-食物列表:用滑动库better-scroll滑动列表、收集列表位移、各子列表top值

本文主要是介绍vue外卖十六:商家-食物列表:用滑动库better-scroll滑动列表、收集列表位移、各子列表top值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、基础页面+基本滑动功能

1)基础页面+逻辑(见附件)

2)滑动库:better-scroll

  1. 官方文档:https://better-scroll.github.io/docs/zh-CN/guide
  2. git :https://github.com/ustbhuangyi/better-scroll

2.1安装

cnpm install @better-scroll/core --save
// or
yarn add @better-scroll/core

2.2使用shop/goods/goods.vue

  1. 动态展现列表数据
  2. 基本滑动:
    使用better-scroll
    理解其基本原理
    创建BScroll对象的时机
    watch + $nextTick()
    callback + $nextTick
<script>import {mapState} from 'vuex'//【1】引入库import BScroll from '@better-scroll/core'export default{mounted(){/*【2】用action触发请求获取食物列表后:再调用nextTick,*相当于vue的watch监听*要配合vuex中actions.js中的callback即:getShopGoods({commit},callback)*/this.$store.dispatch('getShopGoods',()=>{//【3】将回调延迟到下次 DOM 更新循环之后执行this.$nextTick(()=>{//【4】新建一个滚动实例参数是要滚动的DOM的类名new BScroll('.menu-wrapper')//【5】另一个要滚动的DOMnew BScroll('.foods-wrapper')})})},computed:{...mapState(['goods'])},}
</script>

效果:http://localhost:8080/#/shop/goods

按住都可滑动
在这里插入图片描述

二、滑动右侧左侧分类显示当前样式

1.分析+图解

  1. 滑动右侧列表, 左侧同步更新
    better-scroll禁用了原生的dom事件, 使用的是自定义事件
    绑定监听: scroll/scrollEnd
    滚动监听的类型: probeType
    列表滑动的3种类型
    手指触摸
    惯性
    编码
    3.1 分析:
    类名: current 标识当前分类
    设计一个计算属性: currentIndex
    根据哪些数据计算?
    scrollY: 右侧滑动的Y轴坐标 (滑动过程时实时变化)
    tops: 所有右侧分类li的top组成的数组 (列表第一次显示后就不再变化)
    3.2编码:
    1). 在滑动过程中, 实时收集scrollY
    2). 列表第一次显示后, 收集tops
    3). 实现currentIndex的计算逻辑
  2. 点击左侧列表项, 右侧滑动到对应位置
    如图:
    在这里插入图片描述

2.收集食物列表相对于顶点滑动后的实时位移:scrollY

mounted(){this.$store.dispatch('getShopGoods',()=>{//数据更新后执行this.$nextTick(()=>{//列表显示之后创建://新建一个滚动对象:第一个参数是类选择器,第二个参数:配置项const menuScorll=new BScroll('.menu-wrapper')const foodsScorll=new BScroll('.foods-wrapper',{probeType:2 //【1】滑动触发具体条件,惯性滑动不记录:文档>配置项>probeType})/*【2】给食物列表绑定滚动监听:以收集滚动y坐标*参数:scroll:文档api的事件的scroll:文档>api>事件>scroll*/foodsScorll.on('scroll',({x,y})=>{console.log(x,y)//输出一下滑动坐标看看//收集坐标的绝对值y到数据中this.scrollY=Math.abs(y)console.log(this.scrollY) //输出看看})})})}

效果:滚动食物列表,控制台输出:

0 -183
183
0 -734
734
0 -722
722
0 -708
708
0 -687
687
0 -655
655
0 -624
624
0 -585
585

2.1 _initScroll()收集实时位移,单独写成一个方法

mounted(){this.$store.dispatch('getShopGoods',()=>{//数据更新后执行this.$nextTick(()=>{//列表显示之后创建:this._initY() //调用滑动右侧列表,并收集Y位移this._initTop() //调用滑动左侧列表,并收集li的值})})},computed:{...mapState(['goods']),//计算得到当前分类的下标currentIndex(){}},methods:{//【1】收集滑动时top的实时位移数值_initY(){//新建一个滚动对象:第一个参数是类选择器,第二个参数:配置项new BScroll('.menu-wrapper',{})const foodsScorll=new BScroll('.foods-wrapper',{probeType:2 //滑动触发具体条件,惯性滑动不记录:文档>配置项>probeType})/*给食物列表绑定滚动监听:以收集滚动y移位*参数:scroll:文档api的事件的scroll:文档>api>事件>scroll*/foodsScorll.on('scroll',({x,y})=>{// console.log(x,y)this.scrollY=Math.abs(y)console.log(this.scrollY)})},//收集li的值_initTop(){}}

3. _initTop():收集食物列表的tops值

即各个食物子分类top2,top3的Y值

methods:{
//收集li的高度值为数组_initTop(){const tops=[]let top=0tops.push(top)/*结合ul的标识ref=topui,找到所有类名为food-list-hook的元素即*li对象组成的多层对象(此对象含lenght属性)*li内部有一个叫clientHeight记录此li的高度*/const lis=this.$refs.topUi.getElementsByClassName('food-list-hook')// console.log(lis) //打印一下收集到的li们对象组成的数组// console.log(typeof(lis)) //看看其类型// 把lis转换成一个数组,然后逐个读取其高度,并累加计算出每个li的顶部位置传入tops里// Array.prototype.slice.call用法详见:Array.prototype.slice.call(lis).forEach(li=>{// console.log(li)top+=li.clientHeighttops.push(top)})this.tops=topsconsole.log(tops)},
}

4.计算出scrollY位移所处的top在tops中对应的下标

//【2】:class="{current:k===currentIndex}
<li class="menu-item" v-for="(v,k) in goods" :key=k :class="{current:k===currentIndex}" >computed:{...mapState(['goods']),//【1】计算得到当前位移scrollY,所处分类top在tops中的下标currentIndex(){// 取得top0当前位移scrollY,和各食物分类top(n)组成的数组tops[]const {scrollY,tops}=this/* 用findIndex(参数1:当前计算的top值,参数2:当前top的下标)返回*  符合要求的下标*/const index=tops.findIndex((top,index)=>{// 返回下标满足的条件:scrollY>=top,且<下一个topreturn scrollY>=top && scrollY< tops[index+1]})// 返回符合的下标(即当前scrollY位移所处的top在tops中对应的下标)console.log('index:'+index)return index}}

效果:右侧滑动到对应分类,左侧跟着变

在这里插入图片描述

5. 惯性滑动时左侧当前分类不变+变化不准

methods:{//收集滑动食物列表时,列表顶点相对于原位置,在Y轴位移的实时数值_initY(){//新建一个滚动对象:第一个参数是类选择器,第二个参数:配置项new BScroll('.menu-wrapper',{})this.foodsScroll=new BScroll('.foods-wrapper',{probeType:2 //滑动触发具体条件,惯性滑动不记录:文档>配置项>probeType})/*给食物列表绑定滚动监听:以收集滚动y移位*参数:scroll:文档api的事件的scroll:文档>api>事件>scroll*/this.foodsScroll.on('scroll',({x,y})=>{// console.log(x,y)this.scrollY=Math.abs(y)console.log('scrollY:'+this.scrollY)})//【2】只收集惯性滚动结束时的y值// 给右侧列表绑定scroll结束的监听this.foodsScroll.on('scrollEnd', ({x, y}) => {console.log('scrollEnd', x, y)this.scrollY = Math.abs(y)})}
}

6.点左侧右侧自动滚动

//@click="clickMenuItem(k) 点击并传值给对应函数
<li class="menu-item" v-for="(v,k) in goods" :key=k :class="{current:k===currentIndex}" @click="clickMenuItem(k)">methods:{
clickMenuItem(index) {// console.log(index)// 使用右侧列表滑动到对应的位置// 得到目标位置的scrollYconst scrollY = this.tops[index]// 立即更新scrollY(让点击的分类项成为当前分类)this.scrollY = scrollY// 平滑滑动右侧列表 需要2.1步时用this.foodsScroll把它传入this中this.foodsScroll.scrollTo(0, -scrollY, 300)}
}

这篇关于vue外卖十六:商家-食物列表:用滑动库better-scroll滑动列表、收集列表位移、各子列表top值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/965189

相关文章

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

css渐变色背景|<gradient示例详解

《css渐变色背景|<gradient示例详解》CSS渐变是一种从一种颜色平滑过渡到另一种颜色的效果,可以作为元素的背景,它包括线性渐变、径向渐变和锥形渐变,本文介绍css渐变色背景|<gradien... 使用渐变色作为背景可以直接将渐China编程变色用作元素的背景,可以看做是一种特殊的背景图片。(是作为背

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要