vue重构有赞商城-购物车4

2019-05-15  本文已影响0人  陈光展_Gz

一、原生向左滑动显示删除按钮

方法一:
html:

 <li class="block-item block-item-cart"
  :class="{editing:shop.editing}"
  v-for="(good,goodIndex) in shop.goodsList"
  :ref="'goods-'+shopIndex+'-'+goodIndex"
  @touchstart="start($event,good)"
  @touchend="end($event,shopIndex,good,goodIndex)"
 >

js:

import Velocity from 'velocity-animate'
methods:{
  start(e,good){
      good.startX = e.changedTouches[0].clientX
    },
    end(e,shopIndex,good,goodIndex){
      let endX = e.changedTouches[0].clientX
      let left = '0'
      if(good.startX - endX > 100){
        left = '-60px'
      }
      if(endX - good.startX >100){
        left = '0px'
      }
      Velocity(this.$refs[`goods-${shopIndex}-${goodIndex}`],{
        left
      })
    }
 }

方法二:
html:

  <li
   @touchstart="start($event)"
  @touchend="end($event,good)"
   :ref="'good-'+ good.id"
  :class="{'editing':list.editable}"
  v-for="(good,goodIndex) in list.goodsLists"
  :key="good.id"
  class="block-item block-item-cart" style="transition: .5s">
- 根据商品的唯一ID进行操作

js:


    start(e){
       startX = e.changedTouches[0].clientX
    },
    end(e,good){
      endX = e.changedTouches[0].clientX
      if(!this.editingShop){
        let ele = this.$refs[`goods-${good.id}`][0]
        if(startX - endX > 100){
          ele.style.transform = 'translateX(-60px)'
        }else if(endX - startX> 100){
          ele.style.transform = 'translateX(0)'
        }
      }
    }

二、fetch层封装

import axios from 'axios'

function fetch(url,data){
  return new Promise((resolve,reject)=>{
    axios.post(url,data).then(res=>{
      let status = res.data.status
      if(status === 200){
        resolve(res)
      }
      if(status === 300){
        location.href = 'login.html'
        resolve(res)
      }
      resolve(res)
    }).catch(error=>{
      reject(error)
    })
  })
}

export default fetch

三、cartService.js层的封装

import fetch from 'js/fetch.js'
import url from 'js/api.js'

class Cart{
  static add(id){
    return fetch(url.addCart,{
      id,
      number:1
    })
  }
  static reduce(id){
    return fetch(url.cartRemove,{
      id,
      number:1
    })
  }
}

export default Cart

四、删除时候下一个商品继承属性

this.lists.forEach((item,i)=>{
  item.goodsList.forEach(good=>{
  let ele = this.$refs[`goods-${good.id}`][0]//获取所有的商品
  ele.style.transform = 'translateX(0)';//把所有的商品的样式重置
})
上一篇下一篇

猜你喜欢

热点阅读