product.vue 3.2 KB
Newer Older
sin's avatar
sin committed
1
<template>
sin's avatar
sin committed
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
  <div>
    <ul
      :class="'cap-goods-list__container cap-goods-list__container--'+data.classname+' cap-goods-list__container--'+data.ParameterDictionary.showtype+'   '+(data.ParameterDictionary.type=='6'?'nowrap':'')">
      <li v-if="productlist.length==0" style="width:100%;height:150px;border:0px;">
        <div style="width:100%;height:150px;"></div>
      </li>
      <li v-for="(item,index) in productlist" :key="index"
          :class="'cap-goods-list__wrapper  '+(data.ParameterDictionary.type=='3'?(index%3==0?'cap-goods-list__wrapper--hybrid-big ':'cap-goods-list__wrapper--hybrid-small '):'')">
        <router-link
          :class="'cap-goods-list__item cap-goods-list__item--'+data.classname+' '+data.ParameterDictionary.showtype+' '+data.aclass"
          :to="'/product/'+item.id">
          <div class="cap-goods-list__photo">
            <img class="cap-goods-list__img lazy lazyload"
                 v-lazy="item.imageURL+'?w='+((data.ParameterDictionary.type=='1'||data.ParameterDictionary.type=='3')?'750':'375')"/>
          </div>
          <div
            :class="'cap-goods-list__info has-title has-price '+(data.ParameterDictionary.showtype == 'card'?'has-btn':'')">
            <h3 class="title">{{item.title}}</h3>
            <p class="sale-info">
              <span class="sale-price">¥ {{item.price}}</span>
            </p>
          </div>
          <div v-if="data.ParameterDictionary.showtype == 'card'"
               class="cap-goods-list__buy-btn-wrapper cap-goods-list__buy-btn-wrapper--4">
            <button
              class="cap-goods-list__buy-btn-4 van-button van-button--default van-button--small">
              {{data.ParameterDictionary.buttonvalue}}
            </button>
          </div>
        </router-link>
      </li>
sin's avatar
sin committed
33 34
    </ul>
    <div style="clear:both;"></div>
sin's avatar
sin committed
35
  </div>
sin's avatar
sin committed
36 37 38
</template>

<script>
sin's avatar
sin committed
39
  import {getProduct} from "../../api/page.js";
sin's avatar
sin committed
40

sin's avatar
sin committed
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
  export default {
    name: 'product',
    data() {
      return {
        productlist: []
      }
    },
    props: {
      data: Object
    },
    created: function () {
      var id = this.data.PageSectionId;
      var data = this.data;
      var classname = "big";
      var aclass = "";
      switch (data.ParameterDictionary.type) {
        case "1":
          aclass = "cap-goods-list__item--btn1 cap-goods-list__item--ratio-3-2 cap-goods-list__item--whitespace";
          break;
        case "2":
          classname = "small";
          aclass = "cap-goods-list__item--btn1 cap-goods-list__item--padding";
          break;
        case "3":
          classname = "hybrid";
          aclass = "cap-goods-list__item--big cap-goods-list__item--hybrid-big cap-goods-list__item--btn1 cap-goods-list__item--padding";
          break;
        case "4":
          classname = "list";
          aclass = "cap-goods-list__item--btn4 cap-goods-list__item--padding";
          break;
        case "5":
          classname = "three";
          aclass = "cap-goods-list__item--btn4 cap-goods-list__item--padding";
          break;
        case "6":
          classname = "three";
          break;
      }
      data.classname = classname;
      data.aclass = aclass;
      getProduct(id).then(response => {
        this.productlist = response;
      })
sin's avatar
sin committed
85
    }
sin's avatar
sin committed
86
  }
sin's avatar
sin committed
87 88 89 90 91
</script>

<style>

</style>