You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
63 lines
1.1 KiB
63 lines
1.1 KiB
2 years ago
|
Component({
|
||
|
externalClasses: ['wr-class'],
|
||
|
|
||
|
properties: {
|
||
|
goodsList: {
|
||
|
type: Array,
|
||
|
value: [],
|
||
|
},
|
||
|
id: {
|
||
|
type: String,
|
||
|
value: '',
|
||
|
observer: (id) => {
|
||
|
this.genIndependentID(id);
|
||
|
},
|
||
|
},
|
||
|
thresholds: {
|
||
|
type: Array,
|
||
|
value: [],
|
||
|
},
|
||
|
},
|
||
|
|
||
|
data: {
|
||
|
independentID: '',
|
||
|
},
|
||
|
|
||
|
lifetimes: {
|
||
|
ready() {
|
||
|
this.init();
|
||
|
},
|
||
|
},
|
||
|
|
||
|
methods: {
|
||
|
onClickGoods(e) {
|
||
|
const { index } = e.currentTarget.dataset;
|
||
|
this.triggerEvent('click', { ...e.detail, index });
|
||
|
},
|
||
|
|
||
|
onAddCart(e) {
|
||
|
const { index } = e.currentTarget.dataset;
|
||
|
this.triggerEvent('addcart', { ...e.detail, index });
|
||
|
},
|
||
|
|
||
|
onClickGoodsThumb(e) {
|
||
|
const { index } = e.currentTarget.dataset;
|
||
|
this.triggerEvent('thumb', { ...e.detail, index });
|
||
|
},
|
||
|
|
||
|
init() {
|
||
|
this.genIndependentID(this.id || '');
|
||
|
},
|
||
|
|
||
|
genIndependentID(id) {
|
||
|
if (id) {
|
||
|
this.setData({ independentID: id });
|
||
|
} else {
|
||
|
this.setData({
|
||
|
independentID: `goods-list-${~~(Math.random() * 10 ** 8)}`,
|
||
|
});
|
||
|
}
|
||
|
},
|
||
|
},
|
||
|
});
|