1
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
33
34
35
36
37
38
39
40
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
| Component({
| options: {
| addGlobalClass: true,
| },
|
| properties: {
| id: {
| type: String,
| value: '',
| observer(id) {
| this.genIndependentID(id);
| if (this.properties.thresholds?.length) {
| this.createIntersectionObserverHandle();
| }
| },
| },
| data: {
| type: Object,
| observer(data) {
| if (!data) {
| return;
| }
| let isValidityLinePrice = true;
| if (data.originPrice && data.price && data.originPrice < data.price) {
| isValidityLinePrice = false;
| }
| this.setData({ goods: data, isValidityLinePrice });
| },
| },
| currency: {
| type: String,
| value: '¥',
| },
|
| thresholds: {
| type: Array,
| value: [],
| observer(thresholds) {
| if (thresholds && thresholds.length) {
| this.createIntersectionObserverHandle();
| } else {
| this.clearIntersectionObserverHandle();
| }
| },
| },
| },
|
| data: {
| independentID: '',
| goods: { id: '' },
| isValidityLinePrice: false,
| },
|
| lifetimes: {
| ready() {
| this.init();
| },
| detached() {
| this.clear();
| },
| },
|
| pageLifeTimes: {},
|
| methods: {
| clickHandle() {
| this.triggerEvent('click', { goods: this.data.goods });
| },
|
| clickThumbHandle() {
| this.triggerEvent('thumb', { goods: this.data.goods });
| },
|
| addCartHandle(e) {
| const { id } = e.currentTarget;
| const { id: cardID } = e.currentTarget.dataset;
| this.triggerEvent('add-cart', {
| ...e.detail,
| id,
| cardID,
| goods: this.data.goods,
| });
| },
|
| genIndependentID(id) {
| let independentID;
| if (id) {
| independentID = id;
| } else {
| independentID = `goods-card-${~~(Math.random() * 10 ** 8)}`;
| }
| this.setData({ independentID });
| },
|
| init() {
| const { thresholds, id } = this.properties;
| this.genIndependentID(id);
| if (thresholds && thresholds.length) {
| this.createIntersectionObserverHandle();
| }
| },
|
| clear() {
| this.clearIntersectionObserverHandle();
| },
|
| intersectionObserverContext: null,
|
| createIntersectionObserverHandle() {
| if (this.intersectionObserverContext || !this.data.independentID) {
| return;
| }
| this.intersectionObserverContext = this.createIntersectionObserver({
| thresholds: this.properties.thresholds,
| }).relativeToViewport();
|
| this.intersectionObserverContext.observe(
| `#${this.data.independentID}`,
| (res) => {
| this.intersectionObserverCB(res);
| },
| );
| },
|
| intersectionObserverCB() {
| this.triggerEvent('ob', {
| goods: this.data.goods,
| context: this.intersectionObserverContext,
| });
| },
|
| clearIntersectionObserverHandle() {
| if (this.intersectionObserverContext) {
| try {
| this.intersectionObserverContext.disconnect();
| } catch (e) {}
| this.intersectionObserverContext = null;
| }
| },
| },
| });
|
|