3f535f30
杨鑫
'初始'
|
1
2
3
4
|
// import { directive, Swiper, SwiperSlide } from 'vue-awesome-swiper'
// import 'swiper/css/swiper.css'
import {funMixin} from '../../config/mixin'
import api from '../../config/api'
|
a6a3878d
杨鑫
最新绿道
|
5
6
|
const API = require('../../../../config/api')
const NET = require('../../../../utils/request.js')
|
3f535f30
杨鑫
'初始'
|
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
33
34
35
|
export const commonMixin = {
name: 'productList',
mixins: [funMixin],
props: {
terminal: {
type: Number,
default: 4
},
typeId: {
type: Number,
default: 1
},
shopId: {
type: Number,
default: 0
},
componentContent: {
type: Object
}
},
// components: {
// Swiper,
// SwiperSlide
// },
// directives: {
// swiper: directive
// },
data () {
return {
|
a6a3878d
杨鑫
最新绿道
|
36
|
productData: [],
|
3f535f30
杨鑫
'初始'
|
37
38
39
40
41
42
43
44
45
46
47
|
}
},
watch: {
'componentContent': {
handler(newVal, oldVal) {
this.getData()
},
deep: true
}
},
created() {
|
a6a3878d
杨鑫
最新绿道
|
48
|
|
3f535f30
杨鑫
'初始'
|
49
50
51
52
53
54
55
56
57
58
|
this.getData(true)
},
computed: {
swiper() {
if(this.$refs.mySwiper){
return this.$refs.mySwiper.$swiper
}
}
},
methods: {
|
a6a3878d
杨鑫
最新绿道
|
59
60
|
async getData(isFirst) {
const res = await NET.request1(API.vipShop,'','GET')
|
3f535f30
杨鑫
'初始'
|
61
62
63
|
const _ = this
this.productData = [{},{},{},{},{},{},{},{}]
if (_.componentContent.productData.sourceType === '1') {
|
a6a3878d
杨鑫
最新绿道
|
64
|
|
3f535f30
杨鑫
'初始'
|
65
66
|
if(_.componentContent.productData.productIdList && _.componentContent.productData.productIdList.length>0){
_.sendReq({
|
a6a3878d
杨鑫
最新绿道
|
67
|
url: `${api.getProducts}?page=1&pageSize=99&ids=${res.data}`,
|
3f535f30
杨鑫
'初始'
|
68
69
70
71
72
73
74
|
method: 'GET'
}, (proRes) => {
_.productData = proRes.data.list
_.productData = _.productData.filter(item=>JSON.stringify(item) !== '{}')
if(isFirst){
_.componentContent.productData.imgTextData = _.productData
}
|
3f535f30
杨鑫
'初始'
|
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
|
})
} else {
_.productData = []
}
} else if(_.componentContent.productData.sourceType === '2'){
if(_.componentContent.productData.categoryId) {
_.sendReq({
url: `${api.getProducts}?page=1&pageSize=99&classifyId=${_.componentContent.productData.categoryId}`,
method: 'GET'
}, (proRes) => {
_.productData = proRes.data.list
_.productData = _.productData.filter(item=>JSON.stringify(item) !== '{}')
if(isFirst){
_.componentContent.productData.imgTextData = _.productData
}
// _.swiper.update()
})
} else {
_.productData = {
products:[]
}
}
}
},
}
}
|