主体结构
html代码
1 | <div class="seller" ref="seller"> |
seller-contentdiv是能够扩大高度的,能够被内容增加而撑高,而seller div是固定的高度的,从而形成滚动
js代码
1 | import BScroll from 'better-scroll'; |
- 使用watch方法是为了监听数据seller的变化,因为当打开页面的时候,seller是异步获取的,并不一定是能够马上获取,没有seller的数据,相关dom就无法被渲染,并且bscroll是基于dom执行的,所以需要监听seller的变化然后来重新执行相关的初始化函数
- 使用mounted方法是为了保证相关dom渲染完成,因为bscroll是基于dom执行的,但是当切换页面的时候,dom会重新渲染,但未必能够马上完成,所以需要在mounted方法里面重新执行相关的初始化函数
- 关于watch和mounted的使用要基于vue的生命周期来理解vue生命周期
css代码
1 | .seller |
overview部分
html部分
1 | <div class="overview"> |
js部分
1 | import BScroll from 'better-scroll'; |
store.js参考:split,formatDate,store,util组件
css部分
1 | .overview |
bulletin部分
html代码
公告与活动
classMap的原理(classMap使用在之前的header组件使用过Header.vue)
- seller.supports的结构是这样的
1 | “supports”: [ |
- classMap是[‘decrease’, ‘discount’, ‘special’, ‘invoice’, ‘guarantee’]这样的,这个顺序是按照设计需要和数据结构排的,例如type为0对应在线支付满28减5
- 如果要获取对应的class,就可以classMap[seller.supports[index].type],例如seller.supports[0].type就是0,那么就是classMap[0]就是decrease这个class
- 如果要获取对应的description就可以seller.supports[index].description,例如seller.supports[0].description就直接知道了supports数组的第一个元素的description属性的值了
- js代码
1 | import split from '../split/split'; |
使用created方法是为了在加载的时候第一时间完成,因为vue的渲染需要this.classMap属性(created是vue的生命周期的第一个)
css代码
1 | @import “../../common/stylus/mixin.styl” |
pics部分
html代码
商家实景
- ref获取picWrapper是为了滚动图片需要,父DOM是picWrapper,子DOM是picList
- ref获取picList是为了计算图片列表的总长度,用来设置图片列表的横向滚动,因为滚动的触发条件是子DOM比父DOM要”大”的时候才会触发,由于图片的数量是未知的,所以需要去计算,然后写入到picList
js代码
_initPics() { //编程习惯的前置下划线,代表内部使用的方法
1 | if (this.seller.pics) { |
- 一般来说,当某页面本身是垂直滚动的时候,中间的某个DOM需要做横向滚动的话,需要处理滚动坐标的变化,例如手势滚动的时候有x,y坐标,是向上,下,左还是右会区分
- 图片列表的总长度是单个图片的宽度+单个图片的外边距的和乘以图片的数量,再减去最后一个图片的外边距
- BScroll插件需要增加一个属性scrollX: true来传入横向的滚动坐标,也需要增加一个属性eventPassthrough: ‘vertical’过滤垂直的滚动,前者已经解释过,后者是因为需要横向滚动的页面是内嵌在垂直滚动的页面的里面的,所以会造成外面的垂直滚动事件也会传入到横向滚动的页面,为了避免影响横向滚动,所以需要屏蔽垂直滚动的事件
- 我们平时在做这种滚动内嵌滚动的时候也可以参考这个处理方法.
- 另外异步绑定滚动的常规做法,先判断是否已经有BScroll实例了,然后再确定是否需要刷新
css代码
1 | .pics |
info部分
html代码
1 | <div class="info"> |
css代码
1 | .info |